```
From:
                       abbott
Sent:
                       Monday, January 02, 1995 7:12 PM
                       'khp'
To:
Subject:
                       coding suggestion
I was just starting to look at cosines as part of my terp dsplib studies. Looked at your
latest vco code and thought the integrator could be done better. I haven't tested this,
but it should work:
Replace
    tx = gcopy32(x);
    /* initialize sliding integration */
    tz0 = gcopy32(z[0]);
    tz1 = gcopy32(z[0]);
    /* integrate mod 2^32 */
    tx32 = gshl128(tx, 32);
    tx64 = gshl128(tx, 64);
    tx96 = gshl128(tx, 96);
    tz0 = gadd32(tz0, tx);
    tz1 = gadd32(tz1, tx);
    tz0 = gadd32(tz0, tx32);
    tz1 = gadd32(tz1, tx);
    tz0 = gadd32(tz0, tx64);
    tz1 = gadd32(tz1, tx);
    tz0 = gadd32(tz0, tx96);
tz1 = gadd32(tz1, tx);
    tz1 = gadd32(tz1, tx);
    tz1 = gadd32(tz1, tx32);
    tz1 = gadd32(tz1, tx64);
    tz1 = gadd32(tz1, tx96);
with
    tx = gcopy32(x);
    /* initialize sliding integration */
    tz = gcopy32(z[0]);
    /* integrate mod 2^32 */
    tx2 = gshl32(tz, 1);
    tx4 = gshl32(tz, 2);
    tx11 = gexpand32(tx, 32);
    tx21 = gshl128(tx2, 64);
    tx = gadd32(tx, tx11);
    tx = gadd32(tx, tx21);
    tz0 = gadd32(tz, tx);
    tz1 = gadd32(tz0, tx4);
Here's the mathematica (also unchecked)
       = g[32][x, x, x, x];
   tx
   tz
        = g[32][z, z, z, z];
        = g[32][2x, 2x, 2x, 2x];
= g[32][4x, 4x, 4x, 4x];
                                       /* shift */
   tx2
                                       /* shift */
                                        .
/* expand */
   tx11 = g[32][x, 0, x, tx21 = g[32][2x, 2x, 0,
                               0];
                                        /* shift */
                                0];
        = g[32][2x, x, 2x, x];
= g[32][4x, 3x, 2x, x];
                                       /* tx11+tx */
   tx
                                       /* tx21+tx */
   tx
   tz0 = g[32][z+4x, z+3x, z+2x, z+x] /* tz+tx */
        = g[32][z+8x, z+7x, z+6x, z+5x] /* tz0+tx4 */
                                     That should help a little!
Looks like 10 instructions vs 18.
```

- Curtis

From: geert (Geert Rosseel)

Sent: Tuesday, January 03, 1995 10:42 AM

To: 'wampler'

Cc: 'tbr'

Subject: New Euterpe

Hi Kurt,

There is a new placement for Euterpe in

/n/ghidra/s3/geert/euterpe/verilog/bsrc/gards2

Thsi contains the full Euterpe (excluding Cerberus )

Geert

wampler (Kurt Wampler)

Sent:

Tuesday, January 03, 1995 11:08 AM

To:

'geert'

Cc: Subject: 'tbr' Re: New Euterpe

#### Geert writes:

> There is a new placement for Euterpe in

> /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards2

> Thsi contains the full Euterpe (excluding Cerberus )

OK - I've got a copy of the source files; I'll route it and see if things have improved. I should have a line search result early this afternoon.

- Kurt

tbг

Sent:

Tuesday, January 03, 1995 1:26 PM

To:

'geert'

Subject:

euterpe power

Follow Up Flag: Follow up

Flag Status: Red

Where are you building the top level? I'd like to get the latest SOFA power estimate to hand to the mechanical folks. I assume all I need is the total count of isrc's from the SOFA x 30uA each at knob setting 6 to get total current.

Tim

Sent:

tbr (Tim B. Robinson) Tuesday, January 03, 1995 1:26 PM 'geert' euterpe power

To:

Subject:

Where are you building the top level? I'd like to get the latest SOFA power estimate to hand to the mechanical folks. I assume all I need is the total count of isrc's from the SOFA x 30uA each at knob setting 6 to get total current.

Tim

graham (Graham Y. Mostyn)

Sent:

Tuesday, January 03, 1995 5:10 PM

To:

'graham'; 'hessam'; 'abbott'

Subject:

Ře: ISDN

The reason that I raised this issue is that Hessam's mail deemed certain ISDN solutions to be unworkable, but these reasons were specific to Pandora:

eg "Mitel ST bus interface to Calliope and uP bus to Euterpe not feasible since the decision has been made to design the box in a modular fashion... data/address bus needed to run across the modules..."

This argument is not applicable to Hestia.

Now, we did initially talk about modifying the Hestia board to add the 3xISDN capability, but recent thinking has focussed on wireline modules for Pandora. I think there is a need for both, but I just want to be sure that although Pandora has its own mechanical/interconnect constraints, we don't overlook a perhaps easier modification of Hestia.

Hessam, surely Hestia with ISDN can do more than a Combinet function!!

#### Graham.

```
> From abbott@tallis Tue Jan 3 14:56:46 1995
> Date: Tue, 3 Jan 95 14:56:44 -0800
> From: abbott@tallis (Curtis Abbott)
> To: graham@tallis (Graham Y. Mostyn), hessam@tallis
> Subject: ISDN
> Content-Length: 1168
> Graham Y. Mostyn wrote (on Tue Jan 3):
     The recent mail on ISDN has addressed adding a wireline capability
     (ISDN, T1 etc.) to the modular Pandora.
> I'm not sure I agree. The mail that Hessam sent, and that I amplified
> on, addressed changes to Calliope that would allow up to 3 (or perhaps
> more) S interfaces to be connected to a modified Hestia, probably in
> the form of Mitel 8931's, or perhaps the Siemens or National
> equivalents. I'm most anxious to get Alan's thoughts on the proposal
> when he gets back.
> I assume ISDN on modular Pandora is just a matter of plugging a board
> and adding software. Tony has an action to get info on PCI ISDN
> cards, of which there were none 9 months ago, but David B claims there
> are now.
> As to adding Ethernet, I still like the idea very much. This is a
> fairly high bandwidth pipe that's widely used; if it could be cheap,
> it clearly opens opportunities for us.
> As to markets... the point of integrating ISDN relatively cheaply is
> to have a telco pipe to which to apply our computing power. Probably
> for videophone. I don't think anyone's thinking of building "just" a
> Combinet clone with Hestia or Pandora.
> - Curtis
```

From: fwo (Fred Obermeier)

Sent: Tuesday, January 03, 1995 8:29 PM

To: 'hardheads'

Cc: 'fwo'

Subject: Celltest installation.

## Celltest users,

I'm doing a big releasebom of celltest and csyn. We'll be using the new set of csyn rules and csyn signal name mapping. Almost all of the representative leaf cells have passed csyn and celltest with these csyn rules and celltest voltages. Most of the full set of leaf cells have passed rcd1, rcd5, and rcd6 as well. I'm still running on rcd7. I have run tbr\_euterpe-pass1.splvs through these new rules too and the problems have been previously sent. I'm still trying to get another tbr\_euterpe-pass1.splvs built cleanly so that new csyn results can be distributed again.

Of course with these large number of changes to csyn and celltest, there's bound to be something that no longer works, so let me know when you find something.

Fred.

tbr

Sent:

Wednesday, January 04, 1995 12:03 AM

To:

'tom'

Cc:

'geert'

Subject:

proteus/snapshot

Follow Up Flag: Follow up

\_ ..

Flag Status:

Red

I was updating it this evening and made the stupod error of getting the BOM as me rather than chip. I then did a

find -user tbr -exec rm -r {} \;

to clean it up followed by another getbom.

Somehow, the ownership of the compass/layouts directory had become thr so it removed the lot (apparantly) and the new getborn has been grinding on for hours pulling them out again.

I'm a bit worried in case anything nasty might have happened. In particular, I got the following warnings in amongst it all:

/n/auspex/s23/euterpe-proteus-cp: File "Makefile.defs" needs to be evicted (same name as a file that is being extracted) - moving to .#Makefile.defs.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16st1.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16st1.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16st2.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16st2.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "cli.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#cli.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ledsegdrv.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ledsegdrv.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "locked-cells" needs to be evicted (same name as a file that is being extracted) - moving to .#locked-cells.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne\_25xp45.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne\_25xp45.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne\_25xp95\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne\_25xp95\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne\_25xp95\_p45drn.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne\_25xp95\_p45drn.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne\_2xp95\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne\_2xp95\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_25x2p0\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe\_25x2p0\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_25xp45.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe\_25xp45.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_25xp5\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe\_25xp5\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_25xp95\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe\_25xp95\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File

```
"mospe_25xp95_p45drn.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe_25xp95_p45drn.ly.No - (status 16)
```

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_2xp95\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe\_2xp95\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospp\_25x2p0\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospp\_25x2p0\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nf\_25x2p0\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nf\_25x2p0\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nf\_25xp5\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nf\_25xp5\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nfc\_25x1p5\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nfc\_25x1p5\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nfc\_25x2p0\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nfc\_25x2p0\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "npolysc\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#npolysc\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nsas\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nsas\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nsdecendcap\_2udr.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nsdecendcap\_2udr.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nsp\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#nsp\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_bjt1a.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_bjt1a.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_bjt1b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_bjt1b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_cstring1a.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_cstring1a.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_cstring1b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_cstring1b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_nmos1b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_nmos1b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_nmos2b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_nmos2b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_nmos3b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_nmos3b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_pmos2a.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_pmos2a.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_pmos2b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_pmos2b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611\_etest\_1x10\_pmosma.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#p611\_etest\_1x10\_pmosma.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pad\_1x10a.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#pad\_1x10a.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pad\_1x10b.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#pad\_1x10b.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pf\_25x2p0\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#pf\_25x2p0\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pf\_25xp5\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#pf\_25xp5\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ppolysc\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ppolysc\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "proteus.db" needs to be evicted (same name as a file that is being extracted) - moving to .#proteus.db.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "psp\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#psp\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated\_nmos1\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#rotated nmos1\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated\_nmos2\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#rotated\_nmos2\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated pmos1 f.ly" needs to be evicted (same name as a file that is

being extracted) - moving to .#rotated pmos1 f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated\_pmos2\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#rotated\_pmos2\_f.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "subscontfilsca.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#subscontfilsca.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "subscontfilscb.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#subscontfilscb.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "vlsi.cko" needs to be evicted (same name as a file that is being extracted) - moving to .#vlsi.cko.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "vlsi.log" needs to be evicted (same name as a file that is being extracted) - moving to .#vlsi.log.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iobyte0m.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#iobyte0m.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iobytem.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#iobytem.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iocdr2pm.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#iocdr2pm.ly.No - (status 16)

/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iockdrvm.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#iockdrvm.ly.No - (status 16)

and I have no idea why these would have been singled out. Can you take a look at what's there please to see if there is any obvious problem? (Most of the files seem to have execute permission turned on, but I see that is also true in /u/chip).

Thanks Tim From: tbr (Tim B. Robinson)
Sent: Wednesday, January 04, 1995 12:03 AM
To: 'tom'
Cc: 'geert'

Subject: proteus/snapshot

I was updating it this evening and made the stupod error of getting the BOM as me rather than chip. I then  $\operatorname{did}$  a

find -user tbr -exec rm -r {} \;

to clean it up followed by another getbom.

Somehow, the ownership of the compass/layouts directory had become thr so it removed the lot (apparantly) and the new gethom has been grinding on for hours pulling them out again.

I'm a bit worried in case anything nasty might have happened. In particular, I got the following warnings in amongst it all:

/n/auspex/s23/euterpe-proteus-cp: File "Makefile.defs" needs to be evicted (same name as a file that is being extracted) - moving to .#Makefile.defs.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16st1.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#adl6stl.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16st2.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16st2.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "cli.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#cli.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ledsegdrv.ly" needs to be evicted (same name as a file that is being extracted) - moving to . #ledsegdrv.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "locked-cells" needs to be evicted (same name as a file that is being extracted) - moving to .#lockedcells.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne 25xp45.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne 25xp45.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne 25xp95\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne\_ 25xp95 f.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne 25xp95\_p45drn.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne 25xp95 \_p45drn.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mosne 2xp95 f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mosne\_ 2xp95\_f.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe 25x2p0 f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe 25x2p0 f.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe 25xp45.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe 25xp45.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe 25xp5 f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe 25xp5\_f.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_25xp95\_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe\_ 25xp95 f.ly.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_25xp95\_p45drn.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#mospe 25xp95 p45drn.ly.No - (status 16)  $\overline{/}$ n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospe\_2xp95\_f.ly"

```
needs to be evicted (same name as a file that is being extracted) - moving to .#mospe_
2xp95 f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "mospp 25x2p0 f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#mospp_
25x2p0 f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nf_25x2p0_f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#nf_25x2p0
f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nf 25xp5 f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#nf_25xp5
f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nfc_25x1p5_f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#nfc_25x1p5
f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nfc_25x2p0_f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#nfc 25x2p0
 f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "npolysc_f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .
#npolysc f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nsas f.ly" needs to be evicted
(same name as a file that is being extracted) - moving to .#nsas_f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nsdecendcap 2udr.ly" needs to be
evicted (same name as a file that is being extracted) - moving to .#nsdecendcap_2udr.ly.No
- (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "nsp_f.ly" needs to be evicted
(same name as a file that is being extracted) - moving to .#nsp f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611 etest_1x10_bjtla.ly" needs to
be evicted (same name as a file that is being extracted) - moving to .#p611 etest lx10
bjtla.ly.No - (status
16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611 etest 1x10 bjt1b.ly" needs to
be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
bjt1b.ly.No - (status
16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611_etest_lx10_cstring1a.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#p611
etest 1x10 cstring1a.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611 etest_1x10_cstring1b.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#p611
 etest 1x10 cstring1b.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611 etest 1x10 nmoslb.ly" needs
to be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
nmoslb.ly.No - (status
16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611_etest_1x10_nmos2b.ly" needs
to be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
nmos2b.ly.No - (status
16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611_etest_1x10_nmos3b.ly" needs
to be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
nmos3b.ly.No - (status
16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611_etest_1x10_pmos2a.ly" needs
to be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
_pmos2a.ly.No - (status
16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611_etest_1x10_pmos2b.ly" needs
to be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
pmos2b.ly.No - (status
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "p611_etest_1x10_pmosma.ly" needs
to be evicted (same name as a file that is being extracted) - moving to .#p611_etest_1x10
pmosma.ly.No - (status
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pad 1x10a.ly"
needs to be evicted (same name as a file that is being extracted) - moving to . #pad_
```

lx10a.ly.No - (status 16)

```
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pad_1x10b.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#pad_
1x10b.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pf 25x2p0 f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#pf 25x2p0
f.ly.No - (status 16)
\overline{/}n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "pf_25xp5 f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .#pf 25xp5
f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ppolysc f.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .
#ppolysc_f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "proteus.db" needs to be evicted
(same name as a file that is being extracted) - moving to .#proteus.db.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "psp_f.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#psp_f.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated_nmos1_f.ly" needs to be
evicted (same name as a file that is being extracted) - moving to .#rotated_nmos1_f.ly.No
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated nmos2 f.ly" needs to be
evicted (same name as a file that is being extracted) - moving to .#rotated nmos2 f.ly.No
- (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated pmos1 f.ly" needs to be
evicted (same name as a file that is being extracted) - moving to .#rotated_pmos1_f.ly.No
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "rotated pmos2 f.ly" needs to be
evicted (same name as a file that is being extracted) - moving to .#rotated pmos2 f.ly.No
- (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "subscontfilsca.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .
#subscontfilsca.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "subscontfilscb.ly"
needs to be evicted (same name as a file that is being extracted) - moving to .
#subscontfilscb.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "vlsi.cko" needs to be evicted
(same name as a file that is being extracted) - moving to .#vlsi.cko.No - (status 16) /n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "vlsi.log" needs to be evicted
(same name as a file that is being extracted) - moving to .#vlsi.log.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iobyte0m.ly" needs to be evicted
(same name as a file that is being extracted) - moving to .#iobyte0m.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iobytem.ly" needs to be evicted
(same name as a file that is being extracted) - moving to .#iobytem.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iocdr2pm.ly" needs to be evicted
(same name as a file that is being extracted) - moving to .#iocdr2pm.ly.No - (status 16)
/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "iockdrvm.ly" needs to be evicted
(same name as a file that is being extracted) - moving to .#iockdrvm.ly.No - (status 16)
```

and I have no idea why these would have been singled out. Can you take a look at what's there please to see if there is any obvious problem? (Most of the files seem to have execute permission turned on, but I see that is also true in /u/chip).

Thanks Tim

Sent:

Buffalo Chip [chip@rhea] Wednesday, January 04, 1995 5:10 AM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/io BOM 33.0 initiated by brianl completed @ Wed Jan 4
03:08:19 PST 1995 with exit status 0.. chip

lisar (Lisa Robinson)

Sent:

Wednesday, January 04, 1995 10:45 AM

To:

'craig'; 'lisar'

Subject:

Registered copy generated

Copy created by:

lisar

Copy created at:

Wed Jan 4 08:44:32 PST 1995

Copy number:

283

Copy registered to: David Bulfer

Input file:

/u/craig/documents/Terpsichore/Terpsichore.macps.gz.des

Output file:

/u/craig/documents/Terpsichore/Terpsichore.ps

Printed to:

rsh plotter lpr -PCraig

Recorded in file: /u/craig/documents/RegistrationLog

[This message generated by /u/craig/bin/macpstops]

tom (Tom Laidig)

Sent:

Wednesday, January 04, 1995 11:34 AM

To:

'Tim B. Robinson'

Cc:

'geert (Geert Rosseel)'; 'tom (Thomas Laidig)'

Subject: Re: proteus/snapshot

Tim B. Robinson writes:

It was updating it this evening and made the stupod error of getting the BOM as me rather than chip. I then did a

find -user tbr -exec rm -r {} \;

to clean it up followed by another getbom.

Somehow, the ownership of the compass/layouts directory had become the so it removed the lot (apparantly) and the new getbom has been grinding on for hours pulling them out again.

I'm a bit worried in case anything nasty might have happened. In particular, I got the following warnings in amongst it all:

|/n/auspex/s23/euterpe-proteus-cp: File "Makefile.defs" needs to be evicted (same name as a file that is being extracted) - moving to .#Makefile.defs.No - (status 16)

|/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16.ly.No - (status 16)

|/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16st1.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16st1.ly.No - (status 16)

|/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "ad16st2.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#ad16st2.ly.No - (status 16)

|/n/auspex/s23/euterpe-proteus-cp/compass/layouts: File "cli.ly" needs to be evicted (same name as a file that is being extracted) - moving to .#cli.ly.No - (status 16)

[etc.]

and I have no idea why these would have been singled out. Can you take a look at what's there please to see if there is any obvious problem? (Most of the files seem to have execute permission turned on, but I see that is also true in /u/chip).

For reasons unknnown to me (I suspect plain stupidity) compass normally turns on execute permission for layout files. The ones that don't have execute permission set were probably massaged by some text editor or derived some other way originally.

I don't know why these files were singled out, but I suspect the problem in general occurred because when you removed all files owned by the you got rid of the BOM file, so these files appeared as if they existed without being in the BOM. Obviously this doesn't explain why the list is so short. Anyway, I compared all .# files with the corresponding normal files, and found no differences, except for latchx1.ly, which wasn't in your list... apparently, this kind of thing has happened in the past, and the .#latchx1.ly file is way out of date. I suggest

simply deleting these .# files, and forgetting the matter. I'll also fire up a find to see how many more such things we have.

0000O O0000 ( \_) (\_) \( tau )/ ( \_) ( \_)

tbr

Sent:

Wednesday, January 04, 1995 1:35 PM

To:

'geert (Geert Rosseel)'

Subject:

Re: euterpe power

Follow Up Flag: Follow up

Flag Status:

Red

# Geert Rosseel wrote (on Wed Jan 4):

Toplevel is in: /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards

>From the -iter.stat file I see 553357 ISRCs. So I calculate

553357\*30/1000000\*3.3W nominal = 54.8W

for the sofa.

Right now I cannot seem to find the breakdown I had for the rest of the chip. Do you have a copy.

Tim

```
'Fred Obermeier'
To:
Cc:
                     'geert (Geert Rosseel)'
                     Re: tbr_euterpe-pass1.splvs still no connections.
Subject:
Fred Obermeier wrote ....
>Tom,
>Could you take a look a /u/fwo/chip/euterpe/verilog/bsrc? For some
>most of the xbc01 generators are not connected. Intermediate files
should
>Have been saved and the gmake log is FWO.errl. Do you think the
unconnected
>0/1 generators is a problem with my setup or with euterpe?
>% grep -i nc2112 tbr_euterpe-pass1.splvs
>xrgxmituopapcenrqu100 vii6 nc2112 nc2113 vrr6_0 vrr6_1 vrr6_2
xbc0ldfl6s
>% more tbr_euterpe-pass1.csyn
>/error
>error (FloatingInputCheck.1108) in file "tbr_euterpe-pass1.splvs":
   input node has no driver and is not a top-level interface pin
     input
                         top.xdrmux4_13bankadu10.dr_zeroa
>
         instance path:
         cellname path: top.xbmux4dh2s
                                                  .d2_ad0ph
     topmost net
         instance path:
                          top.dr zeroa
         cellname path: top.dr zeroa
> . . .
>Thanks,
>Fred.
I think the problem is out of sync /u/chip/proteus/spice/leaf and /u/chip/proteus/ged/xb
for the c01 generators .
A while back , we deleted the resitor to generate the logic1 output .
/u/chip/proteus/spice/leaf still has the vrr associated with this resistor , but
/u/chip/proteus/ged/xb does not .
tvo
```

vo (Tom Vo)

Wednesday, January 04, 1995 1:47 PM

From:

Sent:

billz (Bill Zuravleff)

Sent:

Wednesday, January 04, 1995 1:48 PM

To:

'euterpe'

Subject:

Cache misses use NB entries

y'all,

Fur asked me to recapitulate cache miss processing to those who make and use the simulator.

Specifically, there was concern that cache miss processing may use more NB entries than expected. Here are some notes:

- 1. Euterpe only processes one cache miss at a time. This is the time from when a miss is detected, until the last hexlet is returned from backing store, is written into the Data array and the tag is updated. If there is a cache miss in another thread during this time it is simply replayed (hiccups).
- 2. A clean cache miss is interpreted by the cache controller as a request for 4 hexlets, which are in turn issued to the NB. The fastest these will be issued to the NB is one per 10 ticks, i.e. as fast as loads can be issued from a single thread.
- 3. A dirty cache miss will similarly cause 4 hexlet loads to be issued to the NB, but first, 4 hexlets are read out of the Data array -- the dirty data -- and sent as hexlet stores to the NB.

The fastest these will be issued to the NB is one per 20 ticks, i.e. as fast as stores can be issued from a single thread.

4. Load and Store requests from the cache controller to the NB are \*low priority\* (recall between all and none of the 16 NB entries are designated low priority, setable by a Cerberus register). If there is no low priority entry available -- the request is rejected -- the cache controller simply retries the request, indefinitely, on a 10 tick beat

(loads) or a 20 tick beat (stores) until all requests are accepted.

Thus for a dirty cache miss, cache miss requests can use up 8 low priority NB entries -- 4 for stores, 4 for loads.

We discussed ways to reduce number of NB entries a cache miss may use; essentially creating a lower-than-low priority level within the NB with the number of lower-than-low priority entries being either a small fixed number, 1 or 2, or Cerberus register settable. We concluded that we have neither atoms nor time to implement these additional features.

Flame me if I'm lying.

Sincerely, billz

fwo (Fred Obermeier)

Sent:

Wednesday, January 04, 1995 2:03 PM

To:

'geert'; 'vo'

Cc:

'fwo'

Subject:

Re: tbr\_euterpe-pass1.splvs still no connections.

Tom,

Thanks for taking a look at the unconnected xbc01 generators in my tbr\_euterpe-pass1.splvs. I presume that either you or Geert will take care of this. Could whomever fixes this let me know when to try and rebuild tbr\_euterpe-pass1.splvs again?

Thanks, Fred.

tbr

Sent:

Wednesday, January 04, 1995 3:17 PM

To:

'bobm'

Subject:

forwarded message from Bill Zuravleff

Follow Up Flag: Follow up

Flag Status:

Red

Is there anything new here we should add to the doc?

----- Start of forwarded message -----

Status: RO

X-VM-v5-Data: ([nil nil nil nil nil nil nil nil nil]

["2021" "Wed" "4" "January" "95" "11:47:39" "PST" "Bill Zuravleff" "billz " nil "49" "Cache misses use NB entries"

"^From:" nil nil "1"])

Return-Path: <billz>

Received: from melpomene.microunity.com by gaea.microunity.com (4.1/muse1.3)

id AA02343; Wed, 4 Jan 95 11:47:42 PST

Received: from localhost by melpomene.microunity.com (8.6.4/muse-sw.3)

id LAA25428; Wed, 4 Jan 1995 11:47:40 -0800

Message-Id: <199501041947.LAA25428@melpomene.microunity.com>

X-Mailer: ELM [version 2.3 PL11]

From: billz (Bill Zuravleff)

To: euterpe

Subject: Cache misses use NB entries Date: Wed, 4 Jan 95 11:47:39 PST

y'all,

Fur asked me to recapitulate cache miss processing to those who make and use the simulator. Specifically, there was concern that cache miss processing may use more NB entries than expected. Here are some notes:

- 1. Euterpe only processes one cache miss at a time. This is the time from when a miss is detected, until the last hexlet is returned from backing store, is written into the Data array and the tag is updated. If there is a cache miss in another thread during this time it is simply replayed (hiccups).
- 2. A clean cache miss is interpreted by the cache controller as a request for 4 hexlets, which are in turn issued to the NB. The fastest these will be issued to the NB is one per 10 ticks, i.e. as fast as loads can be issued from a single thread.
- 3. A dirty cache miss will similarly cause 4 hexlet loads to be issued to the NB, but first, 4 hexlets are read out of the Data array -- the dirty data -- and sent as hexlet stores to the NB. The fastest these will be issued to the NB is one per 20 ticks, i.e. as fast as stores can be issued from a single thread.
- 4. Load and Store requests from the cache controller to the NB are \*low priority\* (recall between all and none of the 16 NB entries are designated low priority, setable

by a Cerberus register). If there is no low priority entry available -- the request is rejected -- the cache controller simply retries the request, indefinitely, on a 10 tick beat (loads) or a 20 tick beat (stores) until all requests are accepted.

Thus for a dirty cache miss, cache miss requests can use up 8 low priority NB entries -- 4 for stores, 4 for loads.

We discussed ways to reduce number of NB entries a cache miss may use; essentially creating a lower-than-low priority level within the NB with the number of lower-than-low priority entries being either a small fixed number, 1 or 2, or Cerberus register settable. We concluded that we have neither atoms nor time to implement these additional features.

Flame me if I'm lying.

Sincerely, billz ----- End of forwarded message -----

chip (Buffalo Chip) From:

Wednesday, January 04, 1995 3:30 PM Sent:

To: 'tbr'

Subject: output of proteus/ikos/lib/.checkoutrc

Wed Jan 4 13:24:08 PST 1995 (tbr Wed, 4 Jan 1995 12:39:47 -0800) proteus/ikos/lib [Release BOM (V17.0) in proteus/ikos/lib (Wed Jan 4 13:24:08 PST 1995)]

| Dir<br>1.1<br>1.14<br>1.6<br>1.1<br>1.4<br>1.1<br>1.3<br>1.1             | proteus/ikos/lib .checkoutrc Makefile buf_lde.pl buf_pin.pl ff_lde.pl ff_pin.pl gate_lde.pl gate_pin.pl tgate_lde.pl tgate_pin.pl                                  | BOM 17.0 |
|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Dir<br>1.1<br>1.2                                                        | proteus/ikos/lib/ikoscells.lde<br>ikoscells.cgbl<br>ikoscells.gbl                                                                                                  | BOM 3.0  |
| Dir<br>1.1<br>1.1<br>1.1<br>1.1<br>1.1<br>1.1<br>1.1<br>1.1<br>1.1<br>1. | proteus/ikos/lib/ikosrams.dwg pin_gen ramtm-I.dwg ramtm-1.ps ramtm-2.dwg ramtm-2.ps ramtm-3.dwg ramtm-3.ps ramtm-4.dwg ramtm-4.ps ramtm-5.dwg ramtm-5.ps spram.dwg | BOM 2.0  |
| Dir<br>1.1<br>1.1<br>1.1                                                 | proteus/ikos/lib/ikosrams.fdt<br>lramcore.fdt<br>ramtime.fdt<br>spcore.fdt                                                                                         | BOM 2.0  |
| Dir<br>1.2<br>2.1<br>1.2<br>1.1<br>1.1<br>1.1<br>1.1<br>1.1              | proteus/ikos/lib/ikosrams.ldt bram.ltt ce_stimrom.ltt ikosrams.gbl lramcore.ldt memlib.ver ramtime.ldt ramtime.ltt spcore.ldt spram.ltt                            | BOM 4.0  |
| Dir<br>1.3                                                               | proteus/ikos/lib/ikosrams.pit<br>allram.ptt                                                                                                                        | BOM 4.0  |

```
1.1
      lramcore.pit
1.1
      ramtime.pit
1.1
      spcore.pit
      proteus/ikos/lib/ikoszdra.dwg
Dir
                                                   BOM 2.0
1.1
      spram.dwg
1.1
      sramtime-1.dwg
1.1
      sramtime-1.ps
1.1
      sramtime-2.dwg
1.1
      sramtime-2.ps
                                                 BOM 2.0
Dir
      proteus/ikos/lib/ikoszdra.fdt
1.1
      lramcore.fdt
1.1
      spcore.fdt
1.1
      sramtime.fdt
Dir
      proteus/ikos/lib/ikoszdra.ldt
                                                 BOM 2.0
1.1
      bram.ltt
1.1
      ce stimrom.ltt
1.1
      ikoszdra.gbl
1.1
      lramcore.ldt
      spcore.ldt
1.1
1.1
      sram.ltt
      sramtime.ldt
1.1
Dir
      proteus/ikos/lib/ikoszdra.pit
                                                 BOM 3.0
1.1
      lramcore.pit
1.1
      spcore.pit
2.1
      sram.ptt
1.1
      sramtime.pit
   => running proteus/ikos/lib/.checkoutrc (Wed Jan 4 13:24:38 PST 1995) <===
mkdir -p ikoszdra.lde
cp ikoszdra.ldt/ikoszdra.gbl ikoszdra.lde/ikoszdra.gbl
IKOSLIB=. LM LICENSE FILE=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0/voyager_license.dat
VOYAGER_HOME=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0 IKOSTMP=ikostmp
IKOSCONF=/n/auspex/s18/chip-proteus/proteus/ikos IKOSLIB=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/lib IKOSB=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0/sys/etc
IKOSERR=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0/sys/etc VOYAGER_MACHINE=sun_sparc
IKOSRAMTMP=ikostmp work=dls_work dls_work= std=dls_std dls_std=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager 2.0/lib/vhdl/sun sparc/std ikos=dls ikos dls ikos=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager 2.0/lib/vhdl/sun sparc/ikos ieee=dls ieee=dls ieee=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/lib/vhdl/sun_sparc/ieee PATH=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/bin/sun_sparc:$PATH /n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/bin/sun_sparc/ramgen ikoszdra ce!
stimrom -p ce stimrom
reading in the lookup table
getting info from libcells.add
beginning to install cells
cell number 0
the cell is lramcore-ce stimrom and the file is lm18998.lde
fault cell id is 1
done restoring
Getting the resolution...
Reading in the pinlist...
Calculating delay values...
Creating simulation files...
Installing the cell into ikoszdra...
Installing into fault library...
saved
cell number i
```

the cell is sramtime-ce stimrom and the file is sm15851.lde

```
fault cell id is 1
done restoring
Getting the resolution...
Reading in the pinlist...
Calculating delay values...
Creating simulation files...
Installing the cell into ikoszdra...
Installing into fault library...
2 out of 2 cells compiled successfully
there were 0 errors or warnings logged
we are done
parsing /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.ldt/ce stimrom.ltt
A = 0.15.1
D = 0.151.1
parsing /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.ldt/lramcore.ldt
tagged cellname = lramcore-ce_stimrom
lde for .gbl is /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.lde/ikoszdra.gbl ldt for .gbl is /N/auspex/root/s18/chip-
proteus/ikos/lib/./ikoszdra.ldt/ikoszdra.gbl
 expanding /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.pit/lramcore.pit to /N/auspex/root/s18/chip-
proteus/ikos/lib/./ikoszdra.pin/lm18998.pin
expanding genram.tmp/lramcore.tde to genram.tmp/lm18998.lde
A = 0.15.1
D = 0.151.1
parsing /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.ldt/sramtime.ldt
tagged cellname = sramtime-ce stimrom
expanding /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.pit/sramtime.pit to /N/auspex/root/s18/chip-
proteus/ikos/lib/./ikoszdra.pin/sm15851.pin
expanding genram.tmp/sramtime.tde to genram.tmp/sm15851.lde
parsing /N/auspex/root/s18/chip-proteus/ikos/lib/./ikoszdra.ldt/ce_stimrom.ltt
 A = 0.15.1
D = 0.151.1
expanding genram.tmp/toptagd.ptt to genram.tmp/sram.pin
Genlibing...
cd ikostmp; for i in `cat ../libcells.add`; do \
        IKOSLIB=.. LM_LICENSE_FILE=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0/voyager_license.dat
VOYAGER_HOME=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0 IKOSTMP=ikostmp
IKOSCONF=/n/auspex/s18/chip-proteus/proteus/ikos IKOSLIB=/n/auspex/s18/chip-proteus/proteus/ikos IKOSLIB=/n/auspex/s18/chip-proteus/proteus/ikos IKOSLIB=/n/auspex/s18/chip-proteus/proteus/ikos IKOSLIB=/n/auspex/s18/chip-proteus/proteus/proteus/ikos IKOSLIB=/n/auspex/s18/chip-proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/proteus/pr
proteus/tools/vendor/ikos/voyager_2.0/lib IKOSB=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0/sys/etc
IKOSERR=/n/auspex/s18/chip-proteus/tools/vendor/ikos/voyager_2.0/sys/etc_VOYAGER_MACHINE=sun_sparc
IKOSRAMTMP=ikostmp work=dls_work dls_work= std=dls_std dls_std=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/lib/vhdl/sun_sparc/std ikos=dls_ikos dls_ikos=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager 2.0/lib/vhdl/sun_sparc/ikos ieee=dls_ieee dls_ieee=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/lib/vhdl/sun_sparc/ieee PATH=/n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager 2.0/bin/sun_sparc:$PATH /n/auspex/s18/chip-
proteus/tools/vendor/ikos/voyager_2.0/bin/sun_sparc/ldex -1 ikoszdr!
a -f $i.lde; \
        awk -f ../ikoszdra.sh/ldeconv.awk $i.lde > ../ikoszdra.lde/$i.lde; \
done
        Translating '../ikoszdra.lde/lm18998.lde'...
        Generating next generation lde file 'lm18998.lde'...
        Reading '../ikoszdra.fle/lm18998.fle'...
        Adding fle data...
        End translating! 1796 lines are translated
        ALCHEMY Ldex Version 1.00 (c) 1993 IKOS SYSTEMS, INC
awk; can't open ../ikoszdra.sh/ldeconv.awk
        Translating '../ikoszdra.lde/sm15851.lde'...
        Generating next generation lde file 'sm15851.lde'...
```

Reading '../ikoszdra.fle/sm15851.fle'...

Adding fle data... End translating! 3859 lines are translated

ALCHEMY Ldex Version 1.00 (c) 1993 IKOS SYSTEMS, INC

awk: can't open ../ikoszdra.sh/ldeconv.awk gmake: \*\*\* [ikoszdra.mac/ce\_stimrom.pin] Error 2 [finished at Wed Jan 4 13:29:50 PST 1995 -- exit status 1] From: lisar (Lisa Robinson)

Sent: Wednesday, January 04, 1995 3:36 PM

To: 'billz'; 'jeffm'
Cc: 'woody'; 'tbr'
Subject: storetiny dump

Is in /n/nosferatu/s2/euterpe/verilog/bsrc/storetiny\_0.\*

Lisa R.

From: Sent: Raymond R. Hayes [hayes@MicroUnity.com] Wednesday, January 04, 1995 7:09 PM

To:

'abbott (Curtis Abbott)'

Cc:

'guarino@MicroUnity.com'; 'kgk@MicroUnity.com'; Alexia Massalin;

'vandyke@MicroUnity.com'

Subject:

Re: Type safety in the Terp compiler....

- > Anyway, what I really want to do is bring up another issue, as long as
- > we're talking compiler directions. Late last year (i.e. 2 weeks ago)
- > I talked with Don about making the compiler return structs in 4 and
- > maybe even 8 registers.

This is pretty easy to do, but does not provide the functionality you desire unless "structure coloring" is also implemented. There is a point in the compiler where, ideally, memory references for every object which can reside solely in a register are removed. At first, this was done for non-aggregate locals which had not had their addresses taken; then it was also applied to non-aggregate globals. Eventually, it will be applied to aggregates and anonymous address expressions. Finally, it will be applied to objects which have had their addresses taken; it is necessary to compute regions over which these objects may be externally visible in order to decide whether they need to be written to memory.

- > I realized a few days ago that if I could pass a struct ptr,
- > dereference it in the static inline and have the compiler keep it in
- > registers, that would be much better for me. Currently, that does not
- > appear to work. (See ~abbott/design/dsp/pulsetest.c for the example I
- > tried it
- > on.) Can one of you discuss the issues here?

There are a couple things going on here:

- One of the fields of the structure is modified in the loop. This may cause the other structure fields to appear to vary, preventing them from being hoisted and adding 5 loads to the body of the loop.
- "Structure coloring" will be necessary to eliminate the load and 2 2 stores associated with the modified field; a load and a store are necessary if the structure is externally visible at the bottom of the loop.
- > Is this as good an idea
- > as it seems, or is there some fatal flaw I don't know about?

I can't think of any fatal flaws, just lots of work which needs to be done to generate the most efficient code. In general, structures cause us the compiler problems because they can be accessed as aggregates or by component; currently, aggregate access can only really be provided through memory. Globals and anything which has had its address taken cause the compiler problems since memory is currently our only globally visible, shared resource; interprocedural register allocation will eventually help us here...

Ray

lisar (Lisa Robinson) From:

Sent: Wednesday, January 04, 1995 8:01 PM

To: 'jeffm'

Cc: 'tbr'; 'mws'; 'billz'; 'woody'; 'dickson'

Subject: pagesize

Jeff you dump of pagesize \*\*\* X CORRUPT:

800040 uu.vldlsDstR15[0]= x \*\*\*

is on rhodan /s3/euterpe/verilog/bsrc/pagesize\_0.\*

Lisa R.

From: Tom Eich [tbe@MicroUnity.com]

Sent: Wednesday, January 04, 1995 8:41 PM

To: 'tbr'

Cc: 'boxers'; 'al'

Subject: Re: Power to the chips.

### Herman forwarded:

```
>Herman Chu wrote (on Wed Jan 4):
>
>
  Hi Tim,
>
>
  The following are the only 2 mail that I can find that have any mentioned
>of
>
   the Eu power. However, I have quite a few email on the Ca power
>
   evolution.
>Thanks. This is inline with what we knew though I do seem to have
>lost the breakdown of the custom section. Based on the latest route
>(which is now essentially complete), I calculate 65W in the sofa at
>nominal power (knob setting 6). We have between 20 and 21W in the
>custom area, so the total is looking like near 85W, up yet again I'm
>afraid from the last guess of 73. I'll double check the custom
>structures, but I don't expect any change there.
>Tim
```

## Some questions:

- 1) Does this have any implications for the calculated Calliope power (last calculated at 54.9W)? I assumed not, but want now to make certain.
- 2) The 85W consumption above is stated for nominal power (knob setting 6). What is the likelyhood of going higher and what would be the maximum you expect in the worst-case? What is the best-case also?
- 3) Are there any plans to spend resources on the problem of reducing the power consumption of the MobiMOS Euterpe this year?

We need your input in order to understand where the increased power may leave the current Hestia design with respect to its product potential and the specifications, as well as to properly bound the packaging problem for Pandora. Unfortunately, the current Hestia design is tapped out wrt power dissipation capacity for realistic product environments (and Noel says it's nearly so wrt power supply capacity).

| I | ħ | anks. |  |
|---|---|-------|--|
|   |   |       |  |

-Tom

Tom Eich | tbe@microunity.com MicroUnity Systems Engineering, Inc.| 255 Caspian Dr. Sunnyvale, CA 94089 | (408)734-8100, (408)734-8136 fax |

tbr

Sent:

Wednesday, January 04, 1995 9:12 PM

To:

'Tom Eich'

Cc:

'al'; 'geert'; 'boxers'

Subject:

Re: Power to the chips.

Follow Up Flag: Follow up

Flag Status:

Red

Tom Eich wrote (on Wed Jan 4):

### Herman forwarded:

```
> Herman Chu wrote (on Wed Jan 4):
> Hi Tim,
> The following are the only 2 mail that I can find that have any mentioned of
> the Eu power. However, I have quite a few email on the Ca power
> evolution.
> Thanks. This is inline with what we knew though I do seem to have
>lost the breakdown of the custom section. Based on the latest route
>(which is now essentially complete), I calculate 65W in the sofa at
>nominal power (knob setting 6). We have between 20 and 21W in the
>custom area, so the total is looking like near 85W, up yet again I'm
>afraid from the last guess of 73. I'll double check the custom
>structures, but I don't expect any change there.
>
```

### Some questions:

1) Does this have any implications for the calculated Calliope power (last calculated at 54.9W)? I assumed not, but want now to make certain.

### No, no change there.

2) The 85W consumption above is stated for nominal power (knob setting 6). What is the likelyhood of going higher and what would be the maximum you expect in the worst-case? What is the best-case also?

We would only turn the knob higher if there is a big difference in the process from the models. This does not necessarily mean more power if we are doing it because the devices are weaker than expected since the higher setting would just be to restore the nominal current levels. We may need to turn up isolated knobs if we have a few timing violations that slip through. There should be zero of these by design. The most we can do is turn the knob to 7 which would be 7/6 of nominal, but as I say, that is likely to be only a few out of 30 or so knobs, so should be a very small effect, certainly less than 10%.

My number (as for the earlier ones) is assuming nominal 3.3V power, so there is also a further 10% if we were operating at 3.6V.

3) Are there any plans to spend resources on the problem of reducing the power consumption of the MobiMOS Euterpe this year?

We are putting effort into making sure the CMOS version will be portable to MOBI, where it should have much lower power than on the foundry process and probably significantly lower power than the bipolar Euterpe. It's too soon yet to tell though what power it is likely to come in at. However, we know for sure the CMOS version will not be near the performance we need for hestia, so it is unlikely to be a solution there. We need the power reduction and to retain the performance.

We need your input in order to understand where the increased power may leave the current Hestia design with respect to its product potential and the specifications, as well as to properly bound the packaging problem for Pandora. Unfortunately, the current Hestia design is tapped out wrt power dissipation capacity for realistic product environments (and Noel says it's nearly so wrt power supply capacity).

I will let geert comment further, but I think we have the circuit resources stretched to do the CMOS version on time, so it's unlikely to me we would be mounting a full scale effort on a wholly new bipolar circuit family in addition to make a major dent in this power by end of 1995.

Tim

tbr

Sent:

Wednesday, January 04, 1995 9:20 PM

To:

'tom': 'brianl'

Cc:

'aeert'

Subject:

snapshot build

Follow Up Flag: Follow up

Flag Status:

Red

I'm a bit worried about the snapshot build I started last night. I thought it was busy doing timing stuff and indeed dealstatus says:

```
deal status at Wed Jan 4 19:17:47 PST 1995
                  user cmd# line started at
from
                                                command
cyclops
                     chip 321 961 Wed Jan 04 19:04:48 echo Making mlt
                   chip 315 943 Wed Jan 04 18:52:11 echo Making mlt
cyclops
          ares
                    chip 288 862 Wed Jan 04 16:56:48 echo Making mlt
cyclops
          hera
                     chip 319 955 Wed Jan 04 19:00:09 echo Making mlt
cyclops
          kephalos
                      chip 326 976 Wed Jan 04 19:12:53 echo Making mlt
cyclops
          merope
                     chip 325 973 Wed Jan 04 19:12:50 echo Making mlt
cyclops
          narcissus
                     chip 322 964 Wed Jan 04 19:05:59 echo Making mlt
cyclops
          pegasus
                     chip 327 979 Wed Jan 04 19:15:08 echo Making mlt
cyclops
          pelorus
                     chip 324 970 Wed Jan 04 19:09:30 echo Making mlt
cyclops
          phobos
          polyhymnia chip 323 967 Wed Jan 04 19:08:19 echo Making mlt
cyclops
cyclops
          psyche
                     chip 328 982 Wed Jan 04 19:16:18 echo Making mlt
cyclops
          thalia
                    chip 320 958 Wed Jan 04 19:03:31 echo Making mlt
with cyclops being the machine I started it from. However the logfail
tbr@aphrodite /n/auspex/s41/euterpe-snapshot/euterpe/proteus 409 % ls -ls maker
 29 -гw-г--г-- 1 chip
                        29615 Jan 4 02:14 makerrs
which has not been touched in 15 hours. If I look at the end of the
log I see:
### finished with or5.pdl -- Wed Jan 4 02:13:11 PST 1995
### doing distributed make on (kephalos psyche boreas phobos rimulac) -- [ Wed Jan 4 02:13:11 PST 1995 ]
# divide the cell list among the available machines
(echo tmp.list.kephalos tmp.list.psyche tmp.list.boreas tmp.list.phobos tmp.list.rimulac; cat /n/auspex/s23/euterpe-proteus-
cp/leafgen/list) \
  |awk'\
    NR == 1 \{ \setminus
           nf = NF;
           for (i = 0; i < nf; i++) \{ \setminus
              file[i] = $(i + 1); 
    NR > 1 \{ print > file[NR \% nf] \}'
```

Exhibit C10

# fire off an rsh on each machine, and wait

for MACH in kephalos psyche boreas phobos rimulac; \

```
do \
    echo "cd `abspath`; \
    nice -15 gmake -wk CELL_LIST=tmp.list.$MACH \
        leaf-layouts > tmp.make.out.$MACH 2>&1" \
        | rsh $MACH sh & \
        sleep 10; \
    done; wait
```

which looks to me like the leaf cell layouts getting built, not the timing run.

Can either of you figure out if it is in fact still doing the right thing?

Thanks

Tim

tbr

Sent:

Wednesday, January 04, 1995 9:33 PM

To:

'lisar'

Subject:

protection problem

Follow Up Flag: Follow up

Flag Status:

Red

Have you been running as you in my bsrc area (IKOS that is)?

I am getting:

override protection 644 for /n/auspex/s15/tbr/euterpe/verilog/bsrc/.cs\_dir/i\_euterpe\_wrap\_tbw-tb.xl/i\_euterpe\_wrap\_tbw.pin?

and unfortunately saying y at that point does not help, it just hangs.

Tim

Raymond R. Hayes [hayes@MicroUnity.com]

Sent: To: Thursday, January 05, 1995 1:27 AM 'abbott (Curtis Abbott)'

To: Cc: Subject:

'vandyke@MicroUnity.com' Re: upgrades to static inlines

```
> I just had a followup conversation with Ray about his response to my
> mail. He pointed out there's still another style -- of passing
> pointers to state vars. I think passing structs may be the optimal
> thing stylistically, but passing pointers is good too.
```

Here's a pretty wacky observation. When a pointer to the struct is passed and a field of the struct is modified in the loop, all of the fields of the struct look as if they vary. If the value of the field to be modified is assigned to a local and the address of that local is passed as well, no struct field is modified in the loop, so all the struct field accesses look invariant and are hoisted out of the loop! Check out the C code appended to this message...

```
> Ray thought it
> was pretty easy -- something to do with where the associate bit gets
> set.
```

The associated bit problem is still there. When INLINE\_FOO is not defined, the compiler can't tell that the modified local is not ex- ternally visible; so the load and store associated with the modified local cannot be eliminated.

There are still a few problems, most notably the dead stores in the structure set-up code; however, the rest of the code looks great, especially when INLINE\_FOO is defined and the memory references as- sociated with the modified local can be removed.

```
Ray
```

```
#include <types.h>
#include <terp/builtins.h>
struct pulses_state
    int accum;
    packed_int8 onvals;
    packed int8 starts;
    packed int8 stops;
    packed int8 incrs;
                        /* oncount+offcount */
    int interval;
};
#if defined (INLINE FOO)
extern short a;
static inline void foo(packed int8 x)
  a += hi64(x);
#endif
static inline packed int8
pulses 8(int *p_accum, struct pulses_state *p) {
    packed_int8 tmp;
    int accum = *p_accum + 16;
    packed int8 onvals = p->onvals, starts = p->starts;
    packed_int8 stops = p->stops, incrs = p->incrs;
    int interval = p->interval;
```

```
tmp = gadd8(incrs, gcopy8(accum));
    tmp = gsetge8(tmp, starts) & gsetl8(tmp, stops);
*p_accum = emux(SET_MASK(accum >= interval), accum - interval, accum);
    return onvals & tmp;
main()
     struct pulses_state p;
    packed_int8 ret1, ret2;
    int i;
    int p_accum;
    p_{accum} = p.accum = 0;
    p.onvals = gcopy8(0x10);
    p.starts = gcopy8(0x28);
p.interval = 0x31;
    p.stops = gcopy8(p.interval);
    p.incrs = 0x0f0e0d0c0b0a09080706050403020100;
    for (i = 0; i < 8; i++) {
       ret1 = pulses_8(&p_accum, &p);
       ret2 = pulses_8(&p_accum, &p);
foo(ret1 ^ ret2);
    p.accum = p_accum;
```

Sent:

Buffalo Chip [chip@rhea] Thursday, January 05, 1995 1:39 AM

To:

'geert@rhea'

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/au BOM 25.0 initiated by dickson completed @ Wed Jan 4
23:35:19 PST 1995 with exit status 0.. chip

billz (Bill Zuravleff)

Sent:

Thursday, January 05, 1995 12:23 PM

To:

Cc:

'tom (Thomas Laidig)'; 'doi (Derek Iverson)' 'tbr (Tim B. Robinson)'; 'dickson (Richard Dickson)'; 'mws (Mark Semmelmeyer)'; 'geert (Geert

Rosseel)'; 'woody (Jay Tomlinson)'

Subject:

releaesbom problem

y'all,

ASAConvenientlyPossible could either of y'all give me some help with releasebom. Problem symptom: releasebom begins releasing BOM is subdirectories, then stops with no diagnostic messages. I'm trying to release BOM 199 in euterpe/verilog/bsrc.

Thanks, billz

Sent:

Buffalo Chip [chip@rhea] Thursday, January 05, 1995 12:31 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/hz BOM 15.0 initiated by dickson completed @ Thu Jan 5
10:27:45 PST 1995 with exit status 0.. chip

Curtis Abbott [abbott@tallis]

Sent:

Thursday, January 05, 1995 1:08 PM

To:

'karzes@tallis'

Cc:

'software@tallis'; 'euterpe@tallis'

Subject:

- Curtis

gextract

I got to thinking about your comments last night about the code I'd written for extracting aligned hexlets from a bizarrely organized frame buffer.

I realized that the instruction pair we talked about can be adapted to do a number of things, including a 2-issue-slot gextract128 and a 2-issue-slot non-immediate gextractN for N<128. In the first case, this improves on the hardware implementation w.r.t. issue slots; in the second case, it provides an instruction that isn't in the hardware in the same number of issue slots as the immediate version that is.

This may be particularly relevant for gextract128, since we have quite a few of these in inner loops. It is not uniformly better than the hardware implementation, since it uses 2 instructions and has a latency of 4 (vs 3), but we are usually issue-slot limited in inner loops, so it will usually be better there.

```
To do gextract128(hi, lo, sh):
   gmshr128(grotr128(hi, sh), lo, sh);

To do gextract64(hi, lo, sh):
   gmshr64(grotr64(hi, sh), lo, sh);

And so on.

Cool, no?
```

From: Sent: Mark Semmelmeyer [mws@tallis] Thursday, January 05, 1995 1:40 PM

To: Cc: 'karzes@tallis'; 'abbott@tallis' 'software@tallis'; 'euterpe@tallis'

Subject:

Re: gextract

```
> From abbott@tallis Thu Jan 5 11:08:01 1995
```

- > a 2-issue-slot gextract128:
  > this improves on the hardware implementation w.r.t. issue slots.
  > It is not uniformly better than the
  > hardware implementation, since it uses 2 instructions and has a
  > latency of 4 (vs 3),
  If EAddI is latency 1, then EShLI is latency 2, and a 3 issue step op like gextract128 in hardware would be latency 4.
  Then your only penalty is code space.
- > but we are usually issue-slot limited in inner loops, so it will
  > usually be better there.
  >
- > To do gextract128(hi, lo, sh):
  > gmshr128(grotr128(hi, sh), lo, sh);
- I am assuming that the compiler or some tool will stuff something useful into the issue slot otherwise wasted between the grotr and gmshr above and created by the XLU-use dependency. Otherwise the effective issue slots available is the same as the hardware implementation.

From: Sent: Scott Furman [fur@quetzalcoatl] Thursday, January 05, 1995 1:44 PM

To:

'Curtis Abbott'

Cc:

'karzes@tallis'; 'software@tallis'; 'euterpe@tallis'

Subject:

gextract

I didn't CC this correctly the first time. Apologies to those who receive two copies.

## Curtis Abbott writes:

> I got to thinking about your comments last night about the code I'd > written for extracting aligned hexlets from a bizarrely organized > frame buffer.

> I realized that the instruction pair we talked about can be adapted to > do a number of things, including a 2-issue-slot gextract128 and a > 2-issue-slot non-immediate gextractN for N<128. In the first case, > this improves on the hardware implementation w.r.t. issue slots; in > the second case, it provides an instruction that isn't in the hardware > in the same number of issue slots as the immediate version that is.

This is not quite the same as a gextract128 because of the recent change which causes a shift count of 128 to be different from a shift count of 0. (What you have emulated with your two-instruction sequence is the "old" gextract128.) Nonetheless, these are good observations, particularly for the gextract128's. (I personally have found only rare uses for non-immediate gextracts with size less than 128.)

> This may be particularly relevant for gextract128, since we have quite > a few of these in inner loops. It is not uniformly better than the > hardware implementation, since it uses 2 instructions and has a > latency of 4 (vs 3), but we are usually issueslot limited in inner > loops, so it will usually be better there.

Something seems fishy here. The current gextract128 implementation takes three issue slots and has latency \*four\* (as described by mws on 10/26/93 and implemented in the simulator). Yet, we can command the hardware to produce almost the same result using two issue slots. (I say "almost" because of the special-case shift count of 128). It seems like the microcoded gextract128 instruction ought to be able to do as well. I wonder what Tom has to say on this matter.

-Scott

From: Sent: Scott Furman [fur@quetzalcoatl] Thursday, January 05, 1995 1:47 PM

gextract

To:

'Curtis Abbott'; 'karzes@tallis'; 'software@tallis'; 'euterpe@tallis'

Subject:

## Scott Furman writes:

- > Something seems fishy here. The current gextract128 implementation
- > takes three issue slots and has latency \*four\* (as described by mws on
- > 10/26/93 and implemented in the simulator). Yet, we can command the

Off-by-one error. Obviously, I meant that our discussion took place on 10/26/94.

-Scott

From: tom (Tom Laidig)

Sent: Thursday, January 05, 1995 1:57 PM

To: 'Bill Zuravleff'

Cc: 'doi (Derek Iverson)'; 'tbr (Tim B. Robinson)'; 'dickson (Richard Dickson)'; 'Mark Semmelmeyer';

'Geert Rosseel'; 'Jay Tomlinson'; 'Thomas Laidig'

Subject: Re: releaesbom problem

Bill Zuravleff writes:

y'all,

ASAConvenientlyPossible could either of y'all give me some help with releasebom. Problem symptom: releasebom begins releasing BOM is subdirectories, then stops with no diagnostic messages. I'm trying to release BOM 199 in heuterpe/verilog/bsrc.

I've just done some sanitizing of the repository, removing old #cvs.\* files (which are cvs's lock files). Try it now...

0000O O0000 (\_) (\_) \( tau )/

chip (Buffalo Chip)

Sent:

Thursday, January 05, 1995 4:13 PM

To:

'billz'

Subject:

output of euterpe/verilog/bsrc/cc/.checkoutrc

The output from euterpe/verilog/bsrc/cc/.checkoutrc is 280k, so it is not included in this mail message. Instead, check the file

/n/tmp/chiplog/billz.ghidra.27411.euterpe-verilog-bsrc-cc

(which is accessible from all machines). This file will disappear in about 5 days.

By the way, the exit status returned by .checkoutrc was 0.

From: chip (Buffalo Chip)
Sent: Thursday, January

Thursday, January 05, 1995 4:32 PM

To: 'billz'

Subject: output of euterpe/verilog/bsrc/.checkoutrc

Thu Jan 5 14:27:41 PST 1995 (billz Thu, 5 Jan 1995 13:36:20 -0800) euterpe/verilog/bsrc [Release BOM (V199.0) in euterpe/verilog/bsrc (Thu Jan 5 14:27:42 PST 1995)]

```
Dir
         euterpe/verilog/bsrc
                                                                     BOM 199.0
32.7
          .checkoutrc
73.1
         1cesnk.ut
         1dr basic.ut
116.1
         Makefile
1.191
(1.188)
         Makefile.share
1.52
         Makefile.tst
40.39
27.14
         Makefile.vo
27.11
         TODO
68.5
         a euterpe wrap.parm
35.3
         analog euterpe.hwc
183.2
         c_euterpe_wrap.parm
35.3
         clockbias.hwc
68.3
         d_euterpe_wrap.parm
80.5
         dcells.pif
7.1
         doexcldlist
80.1
         dummy.rcf
6.332
         euterpe.V
(6.325)
12.6
         euterpe.config
24.20
         euterpe.status
6.76
         euterpe driver.V
6.29
         euterpe_pads.V
15.63
         euterpe_wrap.V
(15.61)
15.4
         euterpe_wrap.parm
134.4
         export_obs
         export subblock
119.4
20.1
         fake.pl
41.10
         genpim2.pl
(41.9)
47.9
         gettst
65.2
         h_euterpe_wrap.parm
12.1
         hwcnets
187.2
         i_euterpe_wrap.tb
         i_euterpe_wrap.vhdl
187.5
91.3
         levellog
134.2
         levelmlog
1.17
         opchart
37.6
         pimlib.pl
(37.5)
131.3
         preptest
70.3
         purgetst
(70.2)
131.1
         runS
134.3
         runvtest
         stashtst
62.10
40.4
         subblk.rcf
52.5
         tbr3_v2e.config
35.1
         toplev.power.tab.local
41.5
         toplev.rcf
         tst_v2e.config
12.2
Dir
         euterpe/verilog/bsrc/at
                                                                     BOM 37.0
```

```
.checkoutrc
4.1
         Makefile
1.9
1.28
         at.V
         at.h
1.5
28.3
         at.power.tab.top
         at_control.pim
3.11
1.2
         atcdwe2.pla
         atcteql.pla
1.1
1.1
         atcylenc.pla
         atdisallowxc.pla
1.3
         atgtlbcnflct.Veqn
25.1
         atgtmissxc.Veqn
1.4
2.1
         atnbreq.Veqn
1.14
         atpadcd. Veqn
1.2
         atpaselgen2.Veqn
1.1
         atpaselgen64.V
1.1
         atpaselgen8.Veqn
         atprchk. Veqn
1.11
1.1
         atvabyp. Veqn
1.2
         atxcenbl.pla
1.1
         atxcfrz.Veqn
         clean-request
4.2
         genatcteq158.pl
1.2
1.1
         genatpasel.pl
3.5
         genpim.pl
3.1
         genptab.pl
3.7
         pimlib.pl
                                                                    BOM 25.0
         euterpe/verilog/bsrc/au
Dir
         .checkoutrc
14.1
1.9
         Makefile
         au.power.tab.top
16.5
         auindx.V
1.17
12.6
         auindx.pim
14.4
         clean-request
12.4
         genpim.pl
12.1
         pimlib.pl
14.3
         power.tab.local
Dir
         euterpe/verilog/bsrc/cc
                                                                    BOM 40.0
9.1
         .checkoutrc
1.14
         Makefile
         cc.V
1.45
23.13
         cc.pim
         cc.power.tab.top
32.2
1.11
         cc.ut
5.9
         cc_control.pim
28.3
         cccount.pla
28.2
         cchexcount.pla
28.7
         ccseq.Veqn
11.11
         ccsm.pla
         ccstart.Vegn
24.2
1.11
         cctester.V
1.1
         cctester.h
         clean-request
14.8
5.9
         genpim.pl
5.6
         pimlib.pl
         power.tab.local
5.1
                                                                    BOM 39.0
Dir
         euterpe/verilog/bsrc/cdio
19.8
         .checkoutrc
         Makefile
1.11
1.16
         cdio.V
         cdio.power.tab.top
34.5
```

```
7.1
         cdio.ut
         cdio_control.pim
28.3
         clean-request
25.5
         genpim.pl
7.5
3.10
         genptab.pl
7.11
         pimlib.pl
Dir
         euterpe/verilog/bsrc/ce
                                                                     BOM 59.0
1.14
         Makefile
         Makefile.gards
1.8
1.1
         ce.config
2.13
         ce_cms2ec1.V
(2.12)
         ce_flash.V
2.11
17.5
         ce_kybd.V
         ce_kybdcntr.V
17.3
32.5
         ce_mck.V
(32.4)
         ce_seg7.V
2.7
1.5
         ceclockbiasbuf.V
1.13
         cecore.V
         cedmctrl.V
1.2
         cedmctrlm.V
1.4
         cedmctrlt.V
1.2
1.8
         cedpreg.V
1.1
         celoosends.V
                                                                         (1.8)
         cemaster.V
1.9
         cerb.in
1.6
         cerbctrlreg.V
1.6
         cerberus.V
1.43
(1.42)
1.14
         cerberus.cpif
1.3
         cerberus.rcf
         cerbnobreg.V
1.5
1.4
         cerbskewreg.V
         cerbtempreg.V
1.7
1.34
         cerbtest.V
1.5
         ceregbuf.V
1.26
         ceregcore.V
         ceslave.V
1.13
1.4
         cetstmux.V
         euterpe/verilog/bsrc/cg
                                                                     BOM 9.0
Dir
1.8
         Makefile
Dir
         euterpe/verilog/bsrc/cj
                                                                     BOM 86.0
         .checkoutrc
46.4
         libr.ut
18.2
18.2
         liss.ut
1.35
         Makefile
         br.tst
2.12
1.17
         cj.V
1.3
         cj.h
62.5
         cj.pim
69.8
         cj.power.tab.top
         cjrst.tst
13.25
48.7
         clean-request
1.8
         free1.tst
42.2
         genpim.pl
47.5
         genptab.pl
         hic.tst
11.16
1.12
         hold.tst
3.16
         ifbr.tst
         ifpred3-11.tst
23.6
20.4
         ifpred3-2.tst
```

| 5.24                                      | micbr.tst                                                                                              |          |
|-------------------------------------------|--------------------------------------------------------------------------------------------------------|----------|
| 5.12                                      | pcbhnd.tst                                                                                             |          |
| 42.3                                      | pimlib.pl                                                                                              |          |
| 78.1                                      | rsrvd.tst                                                                                              |          |
|                                           |                                                                                                        |          |
| Dir                                       | euterpe/verilog/bsrc/ck                                                                                | BOM 21.0 |
|                                           |                                                                                                        |          |
| 10.3                                      | . checkoutrc                                                                                           |          |
| 1.8                                       | Makefile                                                                                               |          |
| 9.2                                       | ck.V                                                                                                   |          |
| 17.4                                      | ck.power.tab.top                                                                                       |          |
| 1.3                                       | cktop.V                                                                                                |          |
| 11.1                                      | clean                                                                                                  |          |
| 12.2                                      | clean-request                                                                                          |          |
| 10.2                                      | genpim.pl                                                                                              |          |
| 10.5                                      | pimlib.pl                                                                                              |          |
| 10.5                                      | prairie.pr                                                                                             |          |
| Dir                                       | euterpe/verilog/bsrc/cp                                                                                | BOM 39.0 |
| 221                                       | cassips, verrisg, sers, op                                                                             |          |
| 9.3                                       | .checkoutrc                                                                                            |          |
| 1.7                                       | Makefile                                                                                               |          |
| 9.4                                       | clean-request                                                                                          | (9.5)    |
| 1.23                                      | cp.V                                                                                                   | (3.3)    |
|                                           | CP. V                                                                                                  |          |
| (1.24)                                    |                                                                                                        |          |
| 7.12                                      | cp.pim                                                                                                 |          |
| (7.13)                                    |                                                                                                        |          |
| 19.5                                      | cp.power.tab.top                                                                                       |          |
| 5.6                                       | genpim.pl                                                                                              |          |
| 5.2                                       | pimlib.pl                                                                                              |          |
| 5.10                                      | power.tab.local                                                                                        |          |
|                                           |                                                                                                        |          |
| Dir                                       | euterpe/verilog/bsrc/ctiod                                                                             | BOM 17.0 |
| 1 0                                       |                                                                                                        |          |
| 1.2                                       | checkoutro                                                                                             |          |
| 1.6                                       | Makefile                                                                                               |          |
| 7.1                                       | bram.init                                                                                              |          |
| 1.5                                       | clean-request                                                                                          |          |
| 7.1                                       | ctd.in                                                                                                 |          |
| 1.3                                       | ctiod.V                                                                                                |          |
| 12.4                                      | ctiod.power.tab.top                                                                                    |          |
| 6.2                                       | ctiod.ut                                                                                               |          |
| 1.3                                       | ctiodtester.V                                                                                          |          |
| 6.1                                       | ctiodtester.h                                                                                          |          |
|                                           |                                                                                                        |          |
| 1.3                                       | ctwe.Veqn                                                                                              |          |
| 1.1                                       | genpim.pl_                                                                                             |          |
| 1.5                                       | genptab.pl                                                                                             |          |
| 1.6                                       | pimlib.pl                                                                                              |          |
|                                           | I I I I I I I I I I I I I I I I I I I                                                                  | DOM 16 0 |
| Dir                                       | euterpe/verilog/bsrc/ctioi                                                                             | BOM 16.0 |
| 3.1                                       | .checkoutrc                                                                                            |          |
|                                           |                                                                                                        |          |
| 1.4                                       | Makefile                                                                                               |          |
| 4.3                                       | clean-request                                                                                          |          |
| 1.8                                       | ctioi.V                                                                                                |          |
| 1.3                                       | ctioi.pim                                                                                              |          |
| 9.5                                       | ctioi.power.tab.top                                                                                    |          |
|                                           | coror.bouer.com                                                                                        |          |
| 1.1                                       | genpim.pl                                                                                              |          |
| $1.1 \\ 1.1$                              | genpim.pl                                                                                              |          |
|                                           |                                                                                                        |          |
| 1.1                                       | <pre>genpim.pl pimlib.pl power.tab.local</pre>                                                         |          |
| 1.1                                       | genpim.pl<br>pimlib.pl                                                                                 | BOM 40.0 |
| 1.1<br>4.5<br>Dir                         | <pre>genpim.pl pimlib.pl power.tab.local euterpe/verilog/bsrc/dp</pre>                                 | BOM 40.0 |
| 1.1<br>4.5<br>Dir<br>1.31                 | <pre>genpim.pl pimlib.pl power.tab.local euterpe/verilog/bsrc/dp Makefile</pre>                        | BOM 40.0 |
| 1.1<br>4.5<br>Dir<br>1.31<br>1.37         | <pre>genpim.pl pimlib.pl power.tab.local euterpe/verilog/bsrc/dp  Makefile dp.V</pre>                  | BOM 40.0 |
| 1.1<br>4.5<br>Dir<br>1.31<br>1.37<br>1.29 | <pre>genpim.pl pimlib.pl power.tab.local euterpe/verilog/bsrc/dp  Makefile dp.V dptop.V</pre>          | BOM 40.0 |
| 1.1<br>4.5<br>Dir<br>1.31<br>1.37         | <pre>genpim.pl pimlib.pl power.tab.local euterpe/verilog/bsrc/dp  Makefile dp.V dptop.V dpwrap.V</pre> | BOM 40.0 |
| 1.1<br>4.5<br>Dir<br>1.31<br>1.37<br>1.29 | <pre>genpim.pl pimlib.pl power.tab.local euterpe/verilog/bsrc/dp  Makefile dp.V dptop.V</pre>          | BOM 40.0 |

```
Dir
         euterpe/verilog/bsrc/dr
                                                                    BOM 51.0
32.3
         .checkoutrc
         Makefile
1.27
         README
1.4
33.5
         clean-request
12.1
         clocksub
1.19
         dr.V
1.1
         dr.clocks.ut
1.13
         dr.config.h
46.2
         dr.pim
43.2
         dr.power.tab.top
1.9
         dr.ut
1.2
         dram.registers
1.1
         drba.pla
7.9
         drbank.V
         drbankarb.pla
1.6
         drbankcsm.pla
1.3
3.5
         drbanksel.Veqn
1.3
         drcd.pla
1.2
         drclockphase.pla
         drcolscram.pla
1.2
         drconfig2bs.pla
4.3
1.3
         drcsm.states.h
         drcsmdecode.pla
1.2
10.3
         drinstantiate.h
1.3
         droktoact.pla
1.2
         droktopre.pla
1.1
         droktoread.pla
1.3
         droktowrite.pla
3.13
         drout.V
5.3
         droutde2Sel.pla
1.4
         drpads.V
         drpagecontrolstack.pla
1.2
1.2
         drpagecsm.pla
1.1
         drpagev.pla
         drpmgen.pla
1.2
1.1
         drpop.pla
3.5
         drprbcsm.pla
         drrc.pla
1.2
1.3
         drreadcount.V
1.2
         drreadcountsel.pla
1.3
         drresetseq.pla
1.2
         drrowscram.pla
1.1
         drrp.pla
         drsamplephase.pla
1.5
1.3
         drseqcheck.pla
         drspacematch.Veqn
3.1
6.2
         drtagqc.pla
         drtester.V
1.15
         drtester.h
1.5
1.8
         drtop.V
         drtop2.V
27.1
1.2
         drwritecount.pla
1.3
         drwritedsel.pla
20.10
         genpim.pl
39.2
         genptab.pl
20.8
         pimlib.pl
1.1
         stripflip
         euterpe/verilog/bsrc/dr/config
Dir
                                                                    BOM 2.0
1.1
         Makefile
         dram.datasheet.explained
1.1
1.1
         dram.datasheet.nec.10
         dram.datasheet.nec.12
1.1
         dram.system.datasheet
1.1
1.1
         marg.c
```

```
system.datasheet.explained
1.1
         euterpe/verilog/bsrc/dr/dram
                                                                    BOM 6.0
Dir
1.4
         Makefile
         README
1.1
         by16_64m.ut
1.1
         by8_16m.ut
1.1
         by8 64m.ut
1.1
         sdram.V
1.1
1.2
         sdram.h
         sdram.small.h
1.1
1.1
         sdram.ut
1.1
         spy.h
         tester.V
1.3
1.1
         tester.h
         euterpe/verilog/bsrc/dr/dram/mit
                                                                    BOM 4.0
Dir
1.3
         Makefile
1.1
         mitsubishi.sdram.model
1.1
         op.v
1.1
         sdram.v
         euterpe/verilog/bsrc/drio
                                                                    BOM 13.0
Dir
3.4
         .checkoutrc
1.4
         Makefile
5.2
         clean-request
         drio.V
1.2
9.4
         drio.power.tab.top
1.1
         genpim.pl
1.1
         pimlib.pl
         power.tab.local
1.1
                                                                    BOM 75.0
Dir
         euterpe/verilog/bsrc/es
45.1
         .checkoutrc
1.23
         Makefile
45.9
         clean-request
         es.V
5.41
5.41
         es.pim
         es.power.tab.top
65.7
40.10
         es xlu.V
1.15
         esaddbyt.V
         esaddbyta.V
60.4
         esalmsum.V
60.3
         esalmsumb.V
60.3
1.27
         esalu64.V
1.10
         escla.V
1.84
         escntrl.V
1.29
         esomux.V
         estop.V
1.4
37.11
         genpim.pl
37.1
         pimlib.pl
13.6
         power.tab.local
Dir
         euterpe/verilog/bsrc/gf
                                                                    BOM 25.0
11.3
         .checkoutrc
1.14
         Makefile
11.5
         clean-request
         genpim.pl
9.6
1.6
         gf.V
         gf.pim
4.7
19.5
         gf.power.tab.top
1.3
         gfbit.pla
1.11
         gfbyt.V
```

```
1.1
         gftop.V
         pimlib.pl
9.1
                                                                     BOM 65.0
         euterpe/verilog/bsrc/gt
Dir
39.3
         .checkoutrc
8.3
         2gtlb.ut
9.4
         3gtltgtlb.ut
1.25
         Makefile
41.5
         clean-request
26.6
         genpim.pl
14.3
         genpipedat.pl
24.4
         genptab.pl
7.15
         gentst.pl
2.20
         gt.V
54.5
         gt.power.tab.top
         gt_control.pim
26.16
7.25
         gt_driver.V
9.4
         gtdone.pla
28.1
         gtibwe.pla
10.12
         gtinstantiate.h
7.4
         gtrdy.pla
7.26
         gtsnake.V
7.5
         gtsnakemuxctl.pla
         gtspmatchearly. Veqn
7.7
7.21
         gtspmatchlate.Veqn
7.4
         gtwe.Veqn
26.8
         pimlib.pl
Dir
         euterpe/verilog/bsrc/hc
                                                                     BOM 74.0
35.8
         .checkoutrc
1.26
         Makefile
         clean-request
40.5
34.4
         genpim0.pl
32.8
         genpim1.pl
12.5
         gentst.pl
1.39
         hc.V
3.13
         hc.h
         hc.ut
8.5
         hc0.power.tab.top
68.3
73.1
         hc0_control.pim
68.3
         hcl.power.tab.top
73.1
         hcl_control.pim
65.1
         hc_brresp.pla
         hc_cmp6.V
6.2
27.17
         hc_control.pim
         hc_device.V
8.8
3.16
         hc driver.V
         hc_error.Veqn
4.2
         hc fifo8.V
12.3
12.3
         hc_fifo8ctrl.Veqn
         hc_ostate.pla
3.12
3.9
         hc parse. Veqn
3.11
         hc_prbctrl.pla
3.2
         hc_rxcrc.Veqn
3.8
         hc_sdecode.Veqn
3.11
         hc_sid.Veqn
         hc_tagmatch.V
3.4
3.2
         hc_txcrc.Veqn
13.1
         hcinstantiate.h
27.4
         pimlib.pl
17.6
         power.tab.local
                                                                    BOM 17.0
Dir
         euterpe/verilog/bsrc/hz
4.2
         .checkoutrc
1.4
         Makefile
```

```
4.4
         clean-request
4.4
         genpim.pl
         hz.V
1.10
9.4
         hz.pim
         hz.power.tab.top
10.3
         hz.ut
1.1
         hz_control.pim
4.1
1.3
         hzmatch.V
         hztester.V
1.6
1.1
         hztester.h
         pimlib.pl
4.2
         power.tab.local
4.1
                                                                     BOM 23.0
Dir
         euterpe/verilog/bsrc/icc
15.1
          .checkoutrc
         Makefile
1.4
3.3
         genpim.pl
1.27
         icc.V
2.5
         icc.h
19.2
         icc.power.tab.top
16.4
         icc_control.pim
15.3
         iccinhife.Veqn
         iccxci6.Veqn
1.8
1.9
         iccxci7.Veqn
3.5
         pimlib.pl
                                                                     BOM 44.0
         euterpe/verilog/bsrc/ife
Dir
18.1
         .checkoutrc
4.2
         1.ut
1.11
         Makefile
18.3
         clean-request
15.5
         genpim.pl
1.2
         if.h
         ifbr.tst
1.7
         ife.V
1.35
40.1
         ife.power.tab.top
15.9
         ife_control.pim
         iffree.tst
1.4
1.4
         iffree5.tst
1.4
         ifhold.tst
1.8
         ifpcseli1.Veqn
2.7
         ifrst.tst
         ifwntdi3.Veqn
1.2
         ifwntdi4.Veqn
1.10
28.1
         ifwntdi6.Veqn
15.2
         pimlib.pl
15.1
         power.tab.local
                                                                     BOM 34.0
         euterpe/verilog/bsrc/io
Dir
         .checkoutrc
9.5
         Makefile
1.15
9.8
         clean-request
8.4
         genpim0.pl
8.5
         genpiml.pl
         io0.power.tab.top
24.4
22.6
         io0_control.pim
24.4
         io1.power.tab.top
22.4
         iol_control.pim
         io buf 8.V
31.1
         io_ififo.V
6.3
         io iphase. Vegn
6.1
6.1
         io ofifo.V
6.1
         io_ophase.Veqn
         io_scioff_6.V
6.2
6.1
         io_scioff_9.V
```

```
3.1
         iocount.pla
3.2
         iodrive.V
         iofs. Vegn
3.1
3.9
         iorate.V
4.7
         pimlib.pl
         power.tab.local
7.3
Dir
         euterpe/verilog/bsrc/iq
                                                                     BOM 51.0
22.3
         .checkoutrc
12.1
         1.ut
         Makefile
1.35
24.6
         clean-request
20.7
         genpim.pl
1,27
         ig.V
50.2
         iq.power.tab.top
20.14
         iq_control.pim
2.6
         iqbr.tst
1.9
         igfree.tst
1.8
         igfree5.tst
1.8
         iqhold.tst
1.9
         iqhold5.tst
1.1
         iqholdq2.Veqn
1.1
         iqholdq7.Veqn
1.4
         iqholdqq.Veqn
3.1
         iqpredq4.Veqn
3.1
         iqpredq9.Veqn
9.3
         iqrst.tst
20.4
         pimlib.pl
20.2
         power.tab.local
Dir
         euterpe/verilog/bsrc/lt
                                                                     BOM 79.0
56.1
         .checkoutrc
3.29
         Makefile
56.6
         clean-request
56.1
         genpim.pl
56.1
         genptab.pl
3.66
         lt.V
68.6
         1t.power.tab.top
56.9
         lt_control.pim
7.7
         ltstldenbl.Veqn
56.10
         pimlib.pl
Dir
         euterpe/verilog/bsrc/mc
                                                                     BOM 55.0
17.3
          .checkoutrc
1.17
         Makefile
17.8
         clean-request
13.9
         genpim.pl
1.19
         mc.V
38.6
         mc.control.obs
         mc.control.pim
48,1
48.1
         mc.dataHigh.pim
48.1
         mc.dataLow.pim
6.22
         mc.pim
         mc.power.tab.top
37.5
14.27
         mc xluc.V
(14.26)
28.2
         mc xlud.V
1.6
         mcacc8.V
         mcaddbyt.V
1.4
1.1
         mcadf32.V
         mcalu64.V
1.11
1.2
         mccla.V
13.2
         pimlib.pl
         power.tab.local
16.2
```

```
Dir
         euterpe/verilog/bsrc/mg
                                                                     BOM 42.0
14.3
         1str.ut
         Makefile
1.30
         dce.in
1.1
         dco.in
1.1
1.3
         mg.h
8.21
         mgrst.tst
1.23
         rslt.tst
10.9
         str.tst
Dir
         euterpe/verilog/bsrc/mst
                                                                     BOM 31.0
13.2
          .checkoutrc
1.15
         Makefile
13.7
         clean-request
11.5
         genpim.pl
20.1
         msacc16.V
1.1
         msadf32.V
1.5
         msbooth.V
20.1
         mscsadd16a.V
         mscsadd16b.V
20.1
         mscsadd16e.V
20.1
         mshotc.V
1.3
         mshotca.V
20.1
20.1
         msin16a.V
20.1
         msin16b.V
         msrcd16.V
20.1
20.1
         msrcd16a.V
         msrcd16b.V
20.1
1.11
         mst.V
2.17
         mst.pim
23.5
         mst.power.tab.top
1.1
         mstop.V
11.1
         pimlib.pl
         euterpe/verilog/bsrc/nb
                                                                     BOM 96.0
Dir
46.5
         .checkoutrc
1.40
         Makefile
         README
1.3
46.7
         clean-request
31.13
         genpim.pl
52.4
         genptab.pl
1.4
         muxff17_1.V
1.4
         muxff17_4.V
         muxff17_5.V
1.2
1.62
         nb.V
31.10
         nb.h
82.5
         nb.power.tab.top
         nb.toplevel.ut
31.4
14.11
         nb.ut
38.33
         nb control.pim
88.5
         nb_mid.pim
88.4
         nb_top.pim
9.18
         nba16x64.tpl
31.19
         nbctrl.Veqn
9.18
         nbd32x64.tpl
1.13
         nbfq.V
44.4
         nbfqcount.pla
1.3
         nbfqprienc.pla
         nbfqslice.pla
1.5
         nbfulllp.pla
44.3
90.1
         nbgotone.V
90.1
         nbgotoneslice. Veqn
         nbholdoff.pla
12.2
         nbholdoff3.pla
68.1
1.13
         nbperiph.V
```

```
1.13
         nbpq.V
1.3
         nbpqhelper.pla
         nbpqptrbit0.Veqn
1.3
         nbpqptrslice.Veqn
1.5
7.4
         nbprbarb. Vegn
7.2
         nbprbcount.pla
1.5
         nbrq.V
         nbrqptrbit0.Veqn
1.3
         nbrqptrslice.Veqn
1.3
1.50
         nbtester.V
1.8
         nbtester.h
8.3
         nbvd.pla
15.5
         nbwe.Veqn
         pimlib.pl
31.13
         euterpe/verilog/bsrc/nb/rf
                                                                     BOM 5.0
Dir
         Makefile
1.4
         rf.ut
1.1
         rflr1w.V
1.4
1.1
         rf1r1w16wx64b.h
         rflr1w32wx64b.h
1.1
         rftester.V
1.1
1.1
         rftester.h
Dir
         euterpe/verilog/bsrc/periph
                                                                     BOM 8.0
1.6
         Makefile
1.1
         README
         p.ut
1.1
3.2
         sptest.ut
Dir
         euterpe/verilog/bsrc/rf
                                                                     BOM 3.0
         1.tst
1.2
1.7
         Makefile
1.3
         dorfspy
1.2
         drvchk.V
         rf_1.V
rf_5.V
1.6
1.5
         rf dec.Veqn
1.3
1.2
         run.V
         spy.V
1.2
         euterpe/verilog/bsrc/rg
                                                                     BOM 97.0
Dir
60.2
         .checkoutrc
14.1
         1br.ut
14.2
         1e.ut
14.3
         1mul.ut
1.47
         Makefile
60.5
         clean-request
19.11
         genpim.pl
         genptab.pl
82.1
19.22
         pimlib.pl
19.2
         power.tab.local
29.14
         rg.V
82.10
         rg.pim
79.5
         rg.power.tab.top
         rg_control.pim
67.3
1.11
         rgcr.V
1.20
         rgdp.V
1.7
         rgimm.V
         rgpc.V
1.27
52.1
         rgplr0.pla
9.19
         rgrst.tst
```

rslt.tst

1.15

```
euterpe/verilog/bsrc/rgxmit
                                                                      BOM 23.0
Dir
1.4
          .checkoutrc
1.3
         Makefile
8.4
         clean-request
1.2
         genpim.pl
1.1
         pimlib.pl
         power.tab.local
1.1
         rgpcbrr7.Veqn
1.2
         rgwewk.Veqn
1.1
1.15
         rgxmit.V
         rgxmit.power.tab.top
19.2
1.5
         rgxmit_control.pim
Dir
         euterpe/verilog/bsrc/sr
                                                                      BOM 49.0
24.5
          .checkoutrc
1.19
         Makefile
26.5
         clean-request
16.9
         genpim.pl
27.5
         genptab.pl
16.11
         pimlib.pl
2.26
         sr.V
(2.25)
3.4
         sr.h
39.5
         sr.power.tab.top
         sr_cla.Veqn
sr_control.pim
1.2
16.19
(16.17)
1.9
         sr driver.V
3.3
         sr_event16.Veqn
         sr_eventreg.V
3.4
16.4
         sr_eventreg.pim
3.5
         sr evmask16.V
         sr_hcevent.V
41.1
         sr_inc4.pla
1.3
1.3
         sr_inc4a.pla
         sr_match.V
2.4
11.1
         sr_mchold.Veqn
sr_radecode.pla
3.3
         sr timer.V
1.3
16.2
         sr_timer.pim
         sr_wadecode.pla
3.2
                                                                      BOM 77.0
Dir
         euterpe/verilog/bsrc/tst
13.2
         le.ut
13.3
         libr.ut
13.2
         liss.ut
13.3
         11.ut
13.2
         1pc.ut
13.1
         1q.ut
13.1
         1str.ut
1.23
         Makefile
1.9
       br.tst
1.60
         drvchk.V
70.1
         ic.tst
         job.tst
6.31
1.11
         rslt.tst
33.12
         rsrvd.tst
1.23
         rst.tst
1.15
         spy.V
3.7
         tstgen
         tstrst.tst
6.27
3.1
         vervars
3.4
         vew
3.1
         vlwire
```

BOM 125.0

60.3 50.7

50.1

50.7

61.6

32.7

50.9

1.2 8.2

14.30

15.10

1.18

28.8

15.21

53.1

76.1

84.5

84.3

1.13

107.3

uuprblmr13.Veqn

uuprblmr5.Veqn

uuprblmr6.Veqn

uuprblmr7.Veqn

uuprblmr8.Veqn

uuprblmr9.Veqn

uuprblmup.Veqn

uuprblmwm.Veqn

uupreemuq.Veqn uupsi.pla

uursltbypcuu.Veqn

uursltbypuu.Veqn

uurbuu.Veqn

uursrvd.tdcd

uuruptr12.Veqn

uurst.tst

uurstuq.pla

uusteput.pla

uustepuu.pla uuthruus.tdcd

```
1.9
         uuthruut.Veqn
1.2
         uuwewj.Veqn
Dir
         euterpe/verilog/bsrc/xlu
                                                                    BOM 47.0
28.2
         .checkoutrc
1.44
         Makefile
8.1
         TODO
25.1
         c1.srf
25.1
         c2.srf
26.1
         c3.srf
36.1
         clean-request
25.1
         cs2.srf
25.1
         cs3.srf
23.2
         db_7a.srf
         dc_8a.srf
21.5
8.20
         qenpim.pl
22.4
         misc2.srf
22.3
         misc3.srf
8.19
         pimlib.pl
35.1
         power.tab.local
         q 9a 7.srf
21.4
19.14
         route.pl
33.7
         x123.pim
40.1
         x126.pim
         x456.pim
33.2
25.1
         xbus.srf
24.8
         xlu.V
14.4
         xlu.mpc
35.1
         xlu.nets
         xlu.noflip
33.1
17.5
         xlu.rcf
33.7
         xlu4.obs
39.1
         xlu6.obs
         xlu_add4.V
41.2
         xlu_ctrldata.c
1.16
         xlu_la_r2.c
1.2
18.2
         xlu_sr.c
28.1
         xlu_sr_c3.dir
xlu_sr_r2.dir
28.3
         xlu sr r3.dir
28.1
         xlu tr s1.c
6.2
28.1
         xlu_tr_s1.dir
6.2
         xlu tr s2.c
28.1
         xlu tr s2.dir
6.2
         xlu_tr_s3.c
         z3.srf
26.1
25.1
         zs3.srf
                                                                    BOM 21.0
Dir
         euterpe/verilog/bsrc/yy
1.14
         Makefile
1.2
         dob2dascii
2,2
         dotestassign
1.20
         tas.pl
2.1
         test.V
1.1
         yy.h
1.5
         yyunasm.V
         yyunasmmnesel.tdcd
1.5
         {\tt yyunasmmusel.tdcd}
1.5
===> running euterpe/verilog/bsrc/.checkoutrc (Thu Jan 5 14:30:46 PST
1995) <===
pager lisar Id: BOM,v 199.0 1995/01/05 13:35:40 LT billz Exp page queued starting paged
for i in at au cc cdio ce cg cj ck cp ctioi ctiod dr drio es gf gt hc hz icc ife io iq lt
mst mc nb rg rgxmit sr uu xlu; do \
      gmake -C ${i} vfiles || exit; \
```

gmake[1]: Entering directory

```
\n/auspex/root/s10/chip/euterpe/verilog/bsrc/at'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/at'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/au'
gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/sl0/chip/euterpe/verilog/bsrc/au'
gmake[1]: Entering directory
\naim /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cc'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cc'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cdio'
gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cdio'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/ce/
cat /n/auspex/s10/chip/euterpe/proteus/verilog/diff.h cerberus.V | /lib/cpp -P -C -B |
sed -e '/^$/d'> cerberus.v.tmp mv cerberus.v.tmp cerberus.v cat
/n/auspex/s10/chip/euterpe/proteus/verilog/diff.h cemaster.V | /lib/cpp -P -C -B | sed -e
'/^$/d'> cemaster.v.tmp cat /n/auspex/s10/chip/euterpe/proteus/verilog/diff.h ce_cms2ecl.V
 /lib/cpp -P -C -B | sed -e '/^$/d'> ce_cms2ecl.v.tmp cat
/n/auspex/s10/chip/euterpe/proteus/verilog/diff.h ce_mck.V | /lib/cpp -P -C -B | sed -e '/
 \$/d'> ce mck.v.tmp mv ce cms2ecl.v.tmp ce cms2ecl.v mv cemaster.v.tmp cemaster.v mv
ce mck.v.tmp ce mck.v echo cerberus.v ceslave.v cecore.v ceregcore.v cerbctrlreg.v
cerbtempreg.v cerbskewreg.v cedpreg.v ceclockbiasbuf.v ceregbuf.v cerbnobreg.v cetstmux.v
cemaster.v ce_flash.v ce_cms2ecl.v ce_kybd.v ce_kybdcntr.v ce_seg7.v ce_mck.v | tr ' '
'\012' > vfiles
gmake[1]: Leaving directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/ce'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cg'
cat /n/auspex/s10/chip/euterpe/proteus/verilog/dxlib/xlib.config
/n/auspex/s10/chip/euterpe/proteus/verilog/dclib/clib.config
/n/auspex/s10/chip/euterpe/proteus/verilog/delib/elib.config > v2e.config cp v2e.config
clockbias.config echo 'lib clockbias = cgclockbias; omit contents clockbias;' >>
clockbias.config CHIPROOT=/n/auspex/s10/chip/euterpe
/n/auspex/s10/chip/euterpe/tools/bin/v2e -host gamorra cgclockbias.v -c clockbias.config
-o cgclockbias.v2e -y /n/auspex/s10/chip/euterpe/proteus/verilog/mlib +libext+.v -y
/n/auspex/s10/chip/euterpe/proteus/verilog/dxlib -y
/n/auspex/s10/chip/euterpe/proteus/verilog/dclib -y
/n/auspex/s10/chip/euterpe/proteus/verilog/delib
V2E 1.0a
          Jan 5, 1995 14:31:12
  * Copyright Cadence Design Systems Inc.
        All Rights Reserved.
                                   Licensed Software.
  * Confidential and proprietary information which is the *
        property of Cadence Design Systems Inc.
Compiling source file "cgclockbias.v"
Scanning library directory
"/n/auspex/s10/chip/euterpe/proteus/verilog/mlib"
Scanning library directory
"/n/auspex/s10/chip/euterpe/proteus/verilog/dxlib"
Scanning library directory
"/n/auspex/s10/chip/euterpe/proteus/verilog/dclib"
Warning! library directory
"/n/auspex/s10/chip/euterpe/proteus/verilog/mlib" was specified but not needed.
Warning! library directory
"/n/auspex/s10/chip/euterpe/proteus/verilog/dxlib" was specified but not needed.
Warning! library directory
"/n/auspex/s10/chip/euterpe/proteus/verilog/delib" was specified but not needed.
Highest level modules:
cqclockbias
```

Reading configuration file clockbias.config ....

```
Processing configuration file ....
Translating Verilog source ....
Writing output to cgclockbias.v2e ....
0 warnings
            0 errors
                  Jan 5, 1995 14:31:26
End of V2E 1.0a
echo cgclockbias.v | tr ' ' '\012' > vfiles
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cg'
gmake[1]: Entering directory
/N/auspex/root/s10/chip/euterpe/verilog/bsrc/cj'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cj'
gmake[1]: Entering directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/ck'gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/ck'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cp'
cat /n/auspex/s10/chip/euterpe/proteus/verilog/diff.h cp.V | /lib/cpp -P -C -B | sed -e
'/^$/d'> cp.v.tmp mv cp.v.tmp cp.v echo cp.v | tr ' ' '\012' > vfiles
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/cp'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/ctioi'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/sl0/chip/euterpe/verilog/bsrc/ctioi'.
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/ctiod'
qmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/ctiod'
gmake[1]: Entering directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/dr'gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/dr'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/drio'
gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/drio'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/es'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/es'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/gf'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
/N/auspex/root/s10/chip/euterpe/verilog/bsrc/gf'
gmake[1]: Entering directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/gt'gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/gt'
gmake[1]: Entering directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/hc'gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
/N/auspex/root/s10/chip/euterpe/verilog/bsrc/hc'
gmake[1]: Entering directory
/N/auspex/root/s10/chip/euterpe/verilog/bsrc/hz'
gmake[1]: `vfiles' is up to date.
```

gmake[1]: Leaving directory

```
\n/auspex/root/s10/chip/euterpe/verilog/bsrc/hz'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/icc'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/icc'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/ife/
gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 '/N/auspex/root/s10/chip/euterpe/verilog/bsrc/ife'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/io'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/io'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/iq'
gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
/N/auspex/root/s10/chip/euterpe/verilog/bsrc/iq'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/lt'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/lt'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/mst'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/mst'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/mc'
cat /n/auspex/s10/chip/euterpe/proteus/verilog/diff.h mc_xluc.V | /lib/cpp -P -C -B | sed
-e '/^$/d'> mc_xluc.v.tmp mv mc_xluc.v.tmp mc_xluc.v echo mc_xlud.v mc_xluc.v mc.v
mcalu64.v mcaddbyt.v mccla.v mcacc8.v mcadf32.v | tr ' ' '\012' > vfiles
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/mc'
gmake[1]: Entering directory
'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/nb'gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/nb'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/rg'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/rg'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/rgxmit'
gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/rgxmit'
gmake[1]: Entering directory
/N/auspex/root/s10/chip/euterpe/verilog/bsrc/sr
cat /n/auspex/s10/chip/euterpe/proteus/verilog/diff.h sr.V | /lib/cpp -P -C -B | sed -e
'/^$/d'> sr.v.tmp mv sr.v.tmp sr.v echo sr.v sr_timer.v sr_match.v sr_eventreg.v
sr_evmask16.v sr_hcevent.v sr_inc4.v sr_inc4a.v sr_radecode.v sr_wadecode.v sr_cla.v
sr_event16.v sr_mchold.v | tr ' ' '\012' > vfiles
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/sr'
gmake[1]: Entering directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/uu'
gmake[1]: 'vfiles' is up to date.
gmake[1]: Leaving directory
 /N/auspex/root/s10/chip/euterpe/verilog/bsrc/uu'
gmake[1]: Entering directory
```

'/N/auspex/root/s10/chip/euterpe/verilog/bsrc/xlu'

gmake[1]: `vfiles' is up to date.
gmake[1]: Leaving directory
 `/N/auspex/root/s10/chip/euterpe/verilog/bsrc/xlu'
rm -f vfiles
for i in at au cc cdio ce cg cj ck cp ctioi ctiod dr drio es gf gt hc hz icc ife io iq lt
mst mc nb rg rgxmit sr uu xlu; do \
 sed -e '/^\$/d' < \${i}/vfiles | sed -e "s!^!\${i}/!" >> vfiles; \ done
 [finished at Thu Jan 5 14:32:22 PST 1995 -- exit status 0]

Curtis Abbott [abbott@tallis]

Sent:

Thursday, January 05, 1995 5:08 PM

To:

'Mark Semmelmeyer'

Cc:

'euterpe@tallis'; 'karzes@tallis'

Subject:

Re: gextract

Mark Semmelmeyer wrote (on Thu Jan 5):

> From abbott@tallis Thu Jan 5 11:08:01 1995

If EAddI is latency 1, then EShLI is latency 2, and a 3 issue step op like gextract128 in hardware would be latency 4. Then your only penalty is code space.

Whoops, I overlooked that. Thanks.

. . .

I am assuming that the compiler or some tool will stuff something useful into the issue slot otherwise wasted...

Yes, the compiler is quite good at it.

Also, Scott points out that gmshr(grotr(...)) does the old, 7-bit shift count gextract128, which I'd overlooked. The old gextract128 is good for aligning hexlets, which is what I was thinking of. The new functionality of the implemented gextract128 is good for lookup in 256 bit tables, so that's not replaced. (However, with a 3 issue slot gextract128, we'd probably use loads -- did for DES at any rate.)

- Curtis

From: geert (Geert Rosseel)

**Sent:** Friday, January 06, 1995 8:59 AM

To: 'billz'; 'brianl'; 'dickson'; 'hopper'; 'mws'; 'tbr'; 'woody'

Subject: nb

nb BOM 96.0 has FATAL timing errors after pass3 and does not iterate

The output is in: /n/auspex/s41/euterpe-snapshot/euterpe/verilog/bsrc/nb

Geert

michael (Chris Michael)

Sent:

Friday, January 06, 1995 12:22 PM

To:

'euterpe'

Subject: Huns models

Design Folk,

The old huns models have been placed in a mobi-like format. The path to the HSPICE model library is:

.lib '/u/chip/technology/huns/hspice/models.lib' huns\_60

## Some notes on the models:

- There are four devices in the models file: NMOS, PMOS, low-Vt NMOS, and NPN. The NMOS, PMOS, and BJT models should function similar to the mobi models (exceptions to this statement will be noted below). The subcircuit name for the low-Vt NMOS is 'NWS' (Vt is -0.14V).
- Library does not include diode, resistor, capacitor, or wire models.
   Just the four transistors.
- No corner models Pspeed, Nspeed, and Bspeed will have no effect.
- Temperature models for the NMOS and PMOS will be accurate only at 25C and 110C. Models aren't reliable at any other temperatures. The low-Vt NMOS model works at 25C only.
- MOS models are Level 3. They exhibit typical Level 3 model problems, including kinks at the transition between linear and saturation regions and poor sub-Vt characteristics. These models probably do not scale well with gate length I would guess that they're only accurate for minimum gate lengths (0.6u for NMOS and PMOS, 0.7u for low-Vt NMOS). There is some attempt at modeling narrow width effects.
- These are old models (at least 2.5 years old), and will undoubtedly be revised once we get more information from the huns. Hopefully, we'll have more complete models at that time.

Chris

craig

Sent:

Friday, January 06, 1995 1:07 PM

To: Cc: 'abbott@tallis'; 'karzes@tallis' 'euterpe@tallis'; 'software@tallis'

Subject:

Re: gextract

The above discussion seems to reinforce previously asserted claims that:

- 1) gextract can be microcoded in two pipeline flows.
- 2) a bypass from second-stage output to second-stage input can improve performance for relatively low implementation cost.

Craig

wampler (Kurt Wampler)

Sent:

Friday, January 06, 1995 5:53 PM

To:

Cc:

'hopper': 'tbr': 'tom': 'vo'

Subject:

Congestion analysis

Hello, Geert,

I'm still getting Euterpe to route to about 99.2% complete before it runs out of resource. I've played around quite a bit with route order, and come to the conclusion that there are some congestion hot spots that just don't have enough tracks, no matter what I do with the route order.

I've put some experimental congestion estimation code into the net select gears program which allows the user to sweep a cut-line across a particular bounded region of the chip at an arbitrary stepping interval and report the number of nets that cross the cut-line at each step. Using this approach, I've analyzed the datapath and the two narrow SOFA "pillars" at the north end of the chip and have some congestion data to report. I have a plot showing regions where the number of required connections exceeds the available routing tracks; the worst numbers are between 1.5 and 2x the number of available tracks. We clearly have some work to do in these regions to alleviate the routing congestion.

I understand you're out sick today, but as soon as you make it back in, I'd like to show you the plot and discuss possible solutions for these problem areas.

The latest routing attempts are in /n/rhodan/s2/wampler/euroute if you want to examine the remaining unroutes. I have a plot of the unroutes also.

- Kurt

hopper (Mark Hofmann)

Sent:

Friday, January 06, 1995 6:01 PM

To:

'Geert Rosseel'

Subject:

Re: nb

Geert Rosseel writes:

nb BOM 96.0 has FATAL timing errors after pass3 and does not iterate

The output is in : /n/auspex/s41/euterpe-snapshot/euterpe/verilog/bsrc/nb

I talked with Billz about this. In trying to fix the global timing error he introduced a local timing error. I'm trying an experiment: I re-mincut NB. I'll see if that gives something that I think might time better at the top level.

-mark

From: Sent: Tom Karzes [karzes@MicroUnity.com] Friday, January 06, 1995 6:34 PM

To: Cc: 'abbott@MicroUnity.com'; 'dickson@MicroUnity.com' 'software@MicroUnity.com', 'euterpe@MicroUnity.com'

Subject:

gextract

Ok, I've had a chance to look at this, and here are my observations.

The 128-bit gextract equivalent given was:

```
> To do gextract128(hi, lo, sh):
> gmshr128(grotr128(hi, sh), lo, sh);
```

As has been pointed out, this only works if the shift amount is < 128. It was also pointed out that the latency of 4 is just as good as the current hardware implementation, which I believe is also 4, with the use of 3 issue slots rather than 2.

A little history on this would probably be helpful. The original plan for using multiple XLU passes for gextract.128 called for an initial pass which would generate a mux mask, followed by a second pass which performed the appropriate shift or rotate on the muxed data. This would have used 2 issue slots and would have had a latency of 3. Since it seemed unlikely that we would improve on this, we didn't give it much more thought and it stood until it came time to implement it. When it was actually implemented, an unpublicized change was made which changed this to 3 issue slots with a latency of 4.

This scheme used the following alogrithm:

The extra work here is computing the mask and using it to mux the hi and lo operands to form the final src operand to the XLU. In the current implementation this step occupies 2 issue slots and adds 2 cycles to the latency, as opposed to the 1 issue slot and 1 additional cycle that was originally planned.

The method Curtis proposes would eliminate the mask and mux completely, and would instead take advantage of the xbus to supply the XLU with a total of 256 operand bits. However, the data on the xbus would first have to be rotated by the XLU. When modified to handle the additional high bit of shift amount, the algorithm would be:

The biggest question here is how easy is it to put the result of the first XLU pass onto the xbus for the second, final pass? Note that it has to be muxed in, and if sh[7] is 1 then it would be suppressed and 0 would be placed on the xbus instead (which is needed for zero fill for unsigned right shift). In addition, the primary input to the final XLU pass would either be hi or lo, again depending on sh[7].

So the question is, would supporting the path from the XLU output to the xbus require adding more gates than would be freed by removing the current logic for generating and using the mux mask? Perhaps Rich can answer this for us.

The 64-bit gextract equivalent given was:

```
> To do gextract64(hi, lo, sh):
> gmshr64(grotr64(hi, sh), lo, sh);
```

This isn't correct. Remember, for group sizes smaller than 128, a gextract is identical to two independent gcompresses. In particular, the hi and lo operand bits never mix; the high 64 bits of the result come from hi and the low 64 bits of the result come from lo. The hardware implements this as a 2-issue, 3-latency operation, which is exactly what you would get if you did this in software (the two gcompresses are independent).

The version shown above has a latency of 4 (since a sequential dependency has been introduced), but more importantly it simply isn't correct. To see this, let's construct a specific example:

hi: aaaaaaaaaaabbbb, ccccccccccdddd lo: eeeeeeeeeeffff, gggggggggghhhh

sh: 16

r: bbbbcccccccccc, ffffggggggggggg

The result of gextract.64(hi, lo, sh) should be r, which is exactly what you'd get by performing a gcompress.64 on hi and a gcompress.64 on lo. However, if you used the translation shown above, you'd get:

grotr: bbbbaaaaaaaaaaa, ddddccccccccccc
gmshr: bbbbeeeeeeeeeee, ddddgggggggggggg

which is clearly incorrect. There may be situations where you'd want this, but is isn't a gextract.

Sent:

Buffalo Chip [chip@rhea] Friday, January 06, 1995 6:49 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert: Release euterpe/verilog/bsrc/sr BOM 50.0 initiated by woody completed @ Fri Jan 6 16:48:18 PST 1995 with exit status 0.. chip

lock read: File exists all ports busy

From: Sent: Curtis Abbott [abbott@tallis] Friday, January 06, 1995 7:16 PM

To:

'Tom Karzes'

Cc:

'dickson@MicroUnity.com'; 'euterpe@MicroUnity.com'

Subject:

aextract

Just a couple of comments on the comments. It was/is not my intention to remotely suggest that we change direction on the current Euterpe implementation. The purpose of the wide broadcast was to alert people to the fact that the somewhat unpleasant 3 issue-slot gextract128 could be replaced, in the purposes we're using it for, with a 2 instruction pair that uses 2 issue-slots. The fact that gextract128 has become somewhat superfluous in this implementation seems to me irrelevant. If we'd noticed earlier, we might have left it out, but it certainly doesn't make sense to go back and rip things up now.

Second, Tom points out that my code for gextractN N<128 doesn't work, and his example makes clear that it would if lo64(hi) and hi64(lo) are swapped (in the 64-bit case -- more generally, a transpose is involved). My apologies. I thought I'd run that case in my test program, but I obviously hadn't.

- Curtis

> > From graham Wed Dec 21 13:31:47 1994 > > Date: Wed, 21 Dec 1994 13:31:43 -0800 > > From: graham (Graham Y. Mostyn) > > To: graham@charybdis, tony@charybdis > > Subject: RE: Euterpe housing containing Calliope > > Cc: yves, hessam, jt > > Content-Length: 807 > Re: the "first-out" minimal interface Calliope: > > I suggest that we might consider various combinations that could > > have market appeal; these are intended to fit in the Euterpe brick > > size, and be low risk (other than d). > > (a) I interpreted your email to suggest just a Calliope with a > > generic digital port that supports various wireline options (and > > perhaps other functions). We would need to consider how the > > wireline electronics might be packaged; perhaps a set of additional >> same-size bricks that also fit in the rack, one for 3xISDN, one for > > T1 etc.?? > That does not make too much sense: instead of designing 2 different bricks > (1. calliope + ISDN, 2. calliope + T1), we will be designing 3 bricks > (1. calliope, 2. ISDN, 3. T1) with all the extra costs : mechanical, > power supply, board, connector ... > There are some limits to modularity. Each time we add a level of > modularity, we add in development cost, production cost and very often > we get a performance hit. > > (b) Audio and NTSC video only. > > (c) Audio and RGB (metal change required for monitor quality) > I don't think calliope can sustain any high quality RGB. What about > EGA or CGA?

agc (Alan Corry)

'Jean-Yves Michel'

Mohajeri)'; 'pandora'

Friday, January 06, 1995 7:17 PM

RE: Euterpe housing containing Calliope

'graham (Graham Y. Mostyn)'; 'tony (Tony Stelliga)'; 'jt (John Tang)'; 'hessam (Hessam

I believe this was discussed at the initial pandora meetings but not disseminated more widely. While it is certainly feasible to make a metal mask change to calliope to allow the current design to provide RGB video at up to a pixel rate of 108Mhz it was deemed unacceptable because of the enormous load it places on euterpe to drive a high-res display (not to mention the internal ring bandwidth that would be hogged by such a device). Other suggestions which came up at the time included modifying mnemosyne to allow the dram interface to support video drams and thereby implement a framestore (eventually the conclusion was to implement the PCI controller mode in a mnemo chip).

Maybe craig and curtis should comment so we can at least document the thread that originally discussed this. I don't doubt that we will have to face the question of an RGB solution other than PCI in some future products.

From:

Sent:

Subject:

To:

Cc:

From: Sent:

Tom Karzes [karzes@MicroUnity.com] Friday, January 06, 1995 7:46 PM

To:

'abbott@MicroUnity.com'

Cc:

'dickson@MicroUnity.com'; 'euterpe@MicroUnity.com'

Subject:

**dextract** 

- > Just a couple of comments on the comments. It was/is not my intention
- > to remotely suggest that we change direction on the current Euterpe
- > implementation. The purpose of the wide broadcast was to alert people
- > to the fact that the somewhat unpleasant 3 issue-slot gextract128
- > could be replaced, in the purposes we're using it for, with a 2
- > instruction pair that uses 2 issue-slots. The fact that gextract128
- > has become somewhat superfluous in this implementation seems to me
- > irrelevant. If we'd noticed earlier, we might have left it out, but
- > it certainly doesn't make sense to go back and rip things up now.

Still, I think there's a lesson here. A 2-issue, 3-latency gextract.128, which was originally proposed as a substitute for a 1-issue, 2-latency version, would have been very useful. At the time it was discussed, it was claimed that it could be done with minimal hardware by using the XLU to generate a mux mask, and this seemed to satisfy everyone.

When it came time to actually implement it, it was found that the 2-issue, 3-latency version that was originally planned would have taken too much additional hardware. At this point, those affected by it should have been notified, and we could have reexamined the problem. If this had been done, it is possible that someone would have suggested an alternative which

\*could\* be implemented as a 2-issue, 3-latency instruction. The suggestion Curtis made may in fact have worked. Instead, the less desirable 3-issue, 4-latency version was implemented, still using the mask/mux approach, and nobody was notified of the problem or the change until after it was done.

This was bad for 2 reasons:

- It eliminated the chance of finding a better way to do it because nobody was looking for it. Of course, there's no guarantee that a better method would have been found, but at least we could have opened the door for it.
- People continued to write code and make timing estimates based on the more optimistic version because they weren't aware of the change. If we had been seriously depending on the 2-issue, 3-latency version in some critical loop, we might have overlooked a serious performance problem until it was too late to do anything about it.

Sigh.

Tim B. Robinson [tbr@gaea.microunity.com]

Sent:

Friday, January 06, 1995 9:16 PM

To:

'Tom Karzes'

Cc:

'abbott@MicroUnity.com'; 'dickson@MicroUnity.com'; 'euterpe@MicroUnity.com';

'software@MicroUnity.com'

Subject:

gextract

Tom Karzes wrote (on Fri Jan 6):

A little history on this would probably be helpful. The original plan for using multiple XLU passes for gextract.128 called for an initial pass which would generate a mux mask, followed by a second pass which performed the appropriate shift or rotate on the muxed data. This would have used 2 issue slots and would have had a latency of 3. Since it seemed unlikely that we would improve on this, we didn't give it much more thought and it stood until it came time to implement it. When it was actually implemented, an unpublicized change was made which changed this to 3 issue slots with a latency of 4.

It may not have been explicitly documented in meeting notes, but it was discussed in two separate euterpe micro-architecture meetings and on both occasions I thought I made it clear we would not be implementing the required additional bypass because we were deparately looking for things to take out of the data path not things to add.

Since then we have removed funtionality (priomarily the 4bit arithmetic ops). We changed our leaf cell family, clocking methodology and lowered the cycle time to gain 15% area, turned up our default power setting again to save area, and finally have done heroic things to get the utilization up to the high 90s % range. As a result it does finally fit and we have so far got it 99.2% routed with very few remaining timing violations.

I stand by that decision not to add the extra stuff in the datapath.

From: Sent: Tom Karzes [karzes@MicroUnity.com] Friday, January 06, 1995 9:50 PM

To:

'tbr@MicroUnity.com'

Cc:

'abbott@MicroUnity.com'; 'dickson@MicroUnity.com'; 'euterpe@MicroUnity.com';

'software@MicroUnity.com'

Subject:

aextract

> It may not have been explicitly documented in meeting notes, but it

- > was discussed in two separate euterpe micro-architecture meetings and
- > on both occasions I thought I made it clear we would not be
- > implementing the required additional bypass because we were deparately
- > looking for things to take out of the data path not things to add.

I certainly understand the need we had to reduce the amount of logic in the data path, and I'm not disagreeing with it. I'm simply making the following points:

- 1. I was unaware of this change at the time it was made.
- I believe Curtis, and most of the other people in software, were unaware of this change as well.
- 3. I don't recall seeing any mail to euterpe, or any other mailing list that I'm on, which mentioned this change (perhaps I missed it, but if so then I wasn't the only one).
- 4. It's not clear to me that the idea Curtis suggested wouldn't result in fewer gates, in addition to reducing the number of issue slots and the latency. It would require the ability to mux the XLU result into the xbus. However, this is \*not\* the same as the additional bypass that was discussed for chaining XLU operations, which would have to feed into the primary XLU input, and would also have a significant impact on the bypass logic. The control for the gextract change would be much simpler than this. Furthermore, there are already muxes in the xbus path (or at least the ability to conditionally zero it), so it may be just a question of whether they're in a convenient point in the pipeline (or could be moved to a convenient point), or whether a significant amount of staging would have to be added to make it work. It may turn out that this solution is too expensive to consider, but then again it may not, and in fact it might even save gates. I simply don't know.

tbr (Tim B. Robinson)

Sent:

Saturday, January 07, 1995 7:09 PM

To:

'Tom Karzes'

Cc:

'abbott@MicroUnity.com'; 'dickson@MicroUnity.com'; 'euterpe'; 'software'; 'lisar'

Subject:

gextract

Tom Karzes wrote (on Fri Jan 6):

- > It may not have been explicitly documented in meeting notes, but it
- > was discussed in two separate euterpe micro-architecture meetings and
- > on both occasions I thought I made it clear we would not be
- > implementing the required additional bypass because we were deparately
- > looking for things to take out of the data path not things to add.

I certainly understand the need we had to reduce the amount of logic in the data path, and I'm not disagreeing with it. I'm simply making the following points:

- 1. I was unaware of this change at the time it was made.
- 2. I believe Curtis, and most of the other people in software, were unaware of this change as well.
- 3. I don't recall seeing any mail to euterpe, or any other mailing list that I'm on, which mentioned this change (perhaps I missed it, but if so then I wasn't the only one).

It was not in any meeting notes I posed, I checked. However, I'm sure curtis was present at the meeting, and I thought you had been there when any significant XLU related issues were discussed. Perhaps the discrepancy came in because the software side assumed such a bypass would be added as a result of just discussing it, when in fact the hardware side had yet to asses the cost. I agree we did not do a good job of following up with the result.

What does the simulator implement. I know lisar has discovered many significant discrepeancies by comparincycle counts on the hardware with those on the simulator and I would have expected one this significant to have shown up there.

4. It's not clear to me that the idea Curtis suggested wouldn't result in fewer gates, in addition to reducing the number of issue slots and the latency. It would require the ability to mux the XLU result into the xbus. However, this is \*not\* the same as the additional bypass that was discussed for chaining XLU operations, which would have to feed into the primary XLU input, and would also have a significant impact on the bypass logic. The control for the gextract change would be much simpler than this. Furthermore, there are already muxes in the xbus path (or at least the ability to conditionally zero it), so it may be just a question of whether they're in a convenient point in the pipeline (or could be moved to a convenient point), or whether a significant amount of staging would have to be added to make it work. It may turn out that this solution is too expensive to consider, but then again it may not, and in fact it might even save gates. I simply don't know.

I agree it's possible curtis's suggestion may save gates, and it's certainly the case that this special case is much cheaper than the general bypass that was originally proposed. However, as we are now more than 6 months behind schedule on getting euterpe taped out I am unwilling to consider changes as significant as this at this stage. Clearly it's something we would revisit in a future major revision.

hopper (Mark Hofmann)

Sent:

Sunday, January 08, 1995 3:02 AM

To:

'geert (Geert Rosseel)'

Subject:

nb

Geert,

I have a much nicer (right edge) placement of NB in

~hopper/chip/euterpe/verilog/bsrc/nb/gards

The right edge is 1640.

I will presently trash this result when I move the arrays left by 60 units.

Do you regard the 560 x-value left edge for the arrays as stable and final? Should I wait?

-mark

tom (Tom Laidig)

Sent:

Sunday, January 08, 1995 2:47 PM

To:

'wampler (Kurt Wampler)'

Cc:

'tom (Thomas Laidig)'; 'ong (Warren R. Ong)'; 'geert (Geert Rosseel)'; 'hopper (Mark

Hofmann)'; 'vo (Tom Vo)'

Subject:

widening power in clock spars?

Warren's examination of power distribution in euterpe found, among other things, that the ends of the clock spars tend to be weak spots.

Although we're making other changes that may be adequate for euterpe, it seems to me that, with modest effort, we could modify the clock/bias construction to widen the clock shield wires into bigger power distribution wires where there aren't actual clock wires to shield.

With the clock distribution scheme we have, this would give us increasing vertical power bussing as one moved away from the mast -- ie, toward the spar ends.

The only downside I can see to doing this is that we would lose the ability for global routing to jog vertically in the clock spars. I don't think this is a serious loss, though... in fact, I vaguely remember we decided to disallow that completely anyway. Is this true?

To widen the M3 shield wires, I envision that a mask layer over the clock distribution section of the clock spars (extending to just include the outer shield wires) would be computed somehow (not sure how, but it seems it shouldn't be too hard), then the clock/bias layout would be post-processed by a vlsimm script. I think the following script (which assumes the clock area mask is in the pseudo-layer `clock\_area\_mask') would do the trick:

```
# Widen M3 clock shields horizontally where possible
# This is done by growing M3 to the left 1 track (20 dbus) and
# cutting out anything that interferes with a right, top, or bottom
# edge of the old M3. Then the same process is repeated for the
# right edge. Only M3 covered by the pseudo-layer `clock_area_mask'
# is widened, although all M3 is examined for conflicts.
flatM3 = flatten(M3);
flatM3 = flatM3 + newM3;
newM3 = newM3
      + grow(clock_area_mask * flatM3, 0, 0, 20, 0)
       - grow(flatM3, 10, 10, 0, 10);
flatM3 = flatM3 + newM3;
M3 = M3 + newM3;
delete newM3;
# Widen V23 as much as possible -- not necessary, but why not?
# This is done by performing a horizontal grow of V23 inside the
# overlap of M2 and M3. Use 2 steps of 10 dbu each to avoid shorts.
# Again, added geometry is limited to the area covered by
# `clock_area_mask' -- not sure why, just paranoid, I guess.
overlap = clock area mask * flatM3 * flatten(M2);
flatV23 = flatten(V23);
newV23 = grow(grow(flatV23, 10, 0, 10, 0) * overlap,
         10, 0, 10, 0) * overlap;
V23 = V23 + (newV23 - flatV23);
delete overlap, flatV23, newV23;
```

ŦŦ

geert (Geert Rosseel) From: Sunday, January 08, 1995 6:23 PM Sent: 'billz'; 'brianl'; 'dickson'; 'geert'; 'hopper'; 'mws'; 'tbr'; 'woody' To: Top-level Euterpe Timing errors Subject: Ηi, Here are the timing violations of the latest top-level run. More detailed info is in : /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards/geert\_euterpe-top.stat (look for HARD ERROR) \*\*\*\* dr to nb : about 50 errors Warning! Cycle time exceeded by 3.91ps using cycle time of 926.00 for Iteration 1 HARD ERROR 1 Path After Optimization using cycle time of 926.00: (xbmuxffb7dh24s 24S) dr/drout/muxff7\_16prblo/u4 Oport: q ad0ph IntDel: 89.60 net: DRprb<4> swg: dh delay: 272 .49ps (force) RC delay: 152.48ps lds: 1 pcap: 20.73ff 585.58ff (ext) m2len: 0.00 m3len: 5135.00 m4len: 0.00 nb/mux4\_16\_prba/u4 (xbmux4dh16s 16S) Iport: D3 AD0PH Oport: q\_adOph IntDel: 83.80 net: nb/prb<4> swg: dh de lay: 119.69ps (force) RC delay: 28.18ps lds: 4 pcap: 44.35ff cap: 266.95ff (ext) m2len: 0.00 m3len: 1152.00 m4len: 8 28.00 nb/mux4\_16\_prba/u4 (xbmux4dh16s 16S) Ipo Oport: q\_adOph IntDel: 83.80 net: nb/prb<4> swg: dh de Iport: D3 AD0PH lds: 4 pcap: 44.35ff lay: 119.69ps (force) RC delay: 28.18ps cap: 266.95ff (ext) m2len: 0.00 m3len: 1152.00 m4len: 8 28.00 nb/muxenff2\_5oq/u0/u0 Iport: D1 AD0PH (xbmuxen2dh16s 16S) Oport: q\_ad0ph IntDel: 72.60 net: nb/muxenff2\_5oq/u0/m swg: dh delay: 4.43ps (force) RC delay: 0.01ps lds: 1 pcap: 7.52ff cap: 11.32ff (ext) m2len: 12.00 m3len: 2 .00 m4len: 0.00 Iport: D0\_ADMPH nb/muxenff2\_5oq/u0/u1 (xbffdh2s 2S) IntDel: 287.30 Time through Path: 929.91 \*\*\* nb to uu : about 60 errors Warning! Cycle time exceeded by 354.80ps using cycle time of 926.00 for Iteration 1 HARD ERROR 53 Path After Optimization using cycle time of 926.00: (xborffb3df32s 32S) nb/nbctrl/Uareforreturn/u0 Oport: Q ADOPF IntDel: 88.00 net: nbWeDX1 N swg: df delay: 926 ds: 29 pcap: 139.27ff cap: uu/UclrNbArryLBsyX2/u0 (xborff3df4s 4S) Iport: D2 A0PF IntDel: 266.30 Time through Path: 1280.80 Warning! Cycle time exceeded by 110.23ps using cycle time of 926.00 for

Exhibit C10

```
HARD ERROR 97
Iteration 1
    Path After Optimization using cycle time of 926.00:
        nb/ff_4_awa/u0 (xbffbdh24s 24S) Oport: q_and0ph IntDe net: nb/awa_N<0> swg: dh delay: 68.71ps (fo RC delay: 21.87ps lds: 3 pcap: 49.91ff cap: 227.01ff
                                                 Oport: q_andOph IntDel:
rce)
(ext) m2len: 0.00 m3len: 1043.00 m4len: 728.00
nb/buf_4_NBawa/u0 (xbbufdh32s 32S)
Oport: q_adOph IntDel: 55.50 net: nbAWaR14<0>
                                                         Iport: DO ANDMPH
        swg: dh delay: 645.61ps (force) RC delay: 461.89ps
                                                                   lds: 1
pcap: 8.84ff cap: 1010.72ff (ext) m2len: 0.00 m3len:
9108.00 m4len: 0.00
                                         Iport: D0_ADMPH IntDel:
        uu/UnbAWaR15/u0 (xbffbdf8s 8S)
176.80
        Time through Path: 1036.23
****
cc to nb : 15 errors
Warning! Cycle time exceeded by 15.18ps using cycle time of 926.00 for
               HARD ERROR 110
Iteration 1
    Path After Optimization using cycle time of 926.00:
        cc/muxff4 lhpb/u0
                                (xbmuxffb4df32s 32S)
                                                          Oport: Q_ADOPF
                                 swg: df delay: 302.28ps (f
IntDel: 87.80 net: CChpbR13
        RC delay: 98.14ps
                                 lds: 8 pcap: 56.32ff cap: 483.23ff
orce)
       m2len: 0.00 m3len: 3881.00 m4len: 0.00
nb/fqcount/Ucout_3_6/u0 (xbor8df32s 32S) Ipo
Oport: Q_ANDOPF IntDel: 229.10 net: nb/fqcount/cout_N_3_6
                                                          Iport: D6 A0PF
        swg: df delay: 50.20ps (force) RC delay: 2.92ps
                                                                   lds: 4
pcap: 28.77ff cap: 87.67ff (ext) m2len: 0.00 m3len: 19
7.00 m4len: 392.00
        nb/fqcount/Ucout_3/u0 (xborff14df6s 6S)
                                                                   Iport:
D7 A0PF IntDel: 271.80
        Time through Path: 941.18
in gt : 45 errors
Warning! Cycle time exceeded by 86.35ps using cycle time of 926.00 for
Iteration 1 HARD ERROR 123
    Path After Optimization using cycle time of 926.00:
        gt/UgtSnake/Upbbo/u16 (xbmuxffb2df32s 32S) Oport: Q_AD0PF
               net: GIpbb<16> swg: df delay: 408.61ps (f
       RC delay: 145.28ps lds: 5 pcap: 44.20ff cap: 579.46ff
(ext) m2len: 0.00 m3len: 4866.00 m4len: 0.00
gt/UgtSnake/UspMtchErly/Uresetrdy_2/u0 (xbor17df32s 32S)
Iport: D0_A0PF Oport: Q_AND0PF IntDel: 244.20 net: gt/Ug
tSnake/UspMtchErly/resetrdy_N_2 swg: df delay: 6.74ps (force) RC delay:
  08ps lds: 1 pcap: 4.92ff cap: 14.42ff (ext) m2len: 0.00 m3len: 13.00 m4len: 82.00
       gt/UgtSnake/UspMtchErly/Uresetrdy/u0
                                                (xborff3df2s 2S)
Iport: D2_AOPF IntDel: 266.30
        Time through Path: 1012.35
****
gt to at : 2 errors
Warning! Cycle time exceeded by 1.18ps using cycle time of 926.00 for
Iteration 1 HARD ERROR 170
    Path After Optimization using cycle time of 926.00:
        gt/UsaoutXorR10/u3 (xbffbdf32s 32S)
                                                          Oport: Q ADOPF
IntDel: 91.30 net: GIsaOutR10<19>
                                       swg: df delay: 145
                                       lds: 5 pcap: 34.51ff cap:
.97ps (force) RC delay: 43.15ps
319.41ff (ext) m2len: 0.00 m3len: 2590.00 m4len: 0.00
```

```
Oport: Q_ANDOPF IntDel: 211.10 net: at/paR10_N<9>
       delay: 228.41ps (force) RC delay: 22.30ps
                                                         lds: 2 pcap:
         cap: 215.90ff (ext) m2len: 0.00 m3len: 1526.00
m4len: 485.00
        at/Upa1509EqfefR11/u0 (xborff7df12s 12S)
                                                                 Iport:
DO_AOPF IntDel: 250.40
       Time through Path: 927.18
***
in uu : 400 errors
Lot's of things like this : Can the mux be merged with the ff ??????
Warning! Cycle time exceeded by 5.51ps using cycle time of 926.00 for
Iteration 1
                HARD ERROR 527
    Path After Optimization using cycle time of 926.00:
                                (xbffbdf32s 32S)
                                                         Oport: Q ADOPF
        uu/UnbDAvailAX0/u1
IntDel: 89.50 net: uu/nbDAvailAX0<1> swg: df delay: 61.
               RC delay: 5.59ps
                                        lds: 4 pcap: 51.31ff
10ps (force)
143.91ff (ext) m2len: 0.00 m3len: 54.00 m4len: 626.00
uu/UnbArryRe4X0/u0 (xbor3dh32s 32S)
Oport: q_and0ph IntDel: 138.20 net: uu/nbArryReX0<4>
g: dh delay: 206.60ps (force) RC delay: 109.12ps
                                                         Iport: D1 A0PF
                                                         lds: 23 pcap:
127.79ff cap: 513.99ff (ext) m2len: 0.00 m3len: 1191.00
m4len: 2671.00
                                (xbmux8dh16s 16S)
        uu/UnbArryHRDstX0/u2
                Oport: q_adOph IntDel: 138.80 net: uu/nbArryHRDs
SEL AOPEH<4>
tX0<2> swg: dh delay: 10.01ps (force) RC delay: 0.36ps
pcap: 7.52ff cap: 29.92ff (ext) m2len: 4.00 m3len: 21
2.00 m4len: 0.00
        uu/UnbArryHRDstX1/u2 (xbffdh2s 2S)
                                                         Iport: D0 ADMPH
IntDel: 287.30
        Time through Path: 931.51
uu to au : 40 errors
Warning! Cycle time exceeded by 64.79ps using cycle time of 926.00 for
             HARD ERROR 944
Iteration 1
    Path After Optimization using cycle time of 926.00:
       uu/UwrapAuLvaSelUXR0/u0 (xbhrdf32s 32S) Oport: Q_ANDOPF IntDel:
244.80 net: UUwrapAuLvaSelUXRO_N<0> swg: df delay: 256
                                        lds: 3 pcap: 22.78ff
.19ps (force)
              RC delay: 87.14ps
444.96ff (ext) m2len: 0.00 m3len: 3838.00 m4len: 0.00
                                                Iport: D1_A0PF Oport:
                       (xbor3dh32s 32S)
        au/u202/u0
q_ad0ph IntDel: 138.20 net: au/sfrc14a n
                                                 swg: dh de
lay: 5.57ps (force)
                      RC delay: 0.32ps
                                                lds: 1 pcap: 5.99ff
cap: 27.59ff (ext) m2len: 0.00 m3len: 6.00 m4len: 210.0 0
        au/u208/u0/u0 (xbmuxen2dh16s 16S)
                                                Iport: SEL_A0PEH<0>
Oport: q_andOph IntDel: 118.90 net: au/u208/u0/m_N
                                                         SW
        \overline{\text{delay}}: 10.93ps (force) RC delay: 0.28ps
                                                         lds: 1 pcap:
g: dh
          cap: 26.95ff (ext) m2len: 0.00 m3len: 27.00 m4l
8.85ff
en: 154.00
                                                 Iport: DO ANDMPH
        au/u208/u0/u1
                        (xbffdf4s 4S)
IntDel: 216.20
        Time through Path: 990.79
****
uu to rgxmit
* * * *
```

```
Warning! Cycle time exceeded by 27.28ps using cycle time of 926.00 for
Iteration 1
              HARD ERROR 1002
    Path After Optimization using cycle time of 926.00:
       uu/holduu/UinSellCUQ_1/u0
                                       (xborffb7dh24s 24S)
q andOph IntDel: 89.60 net: uu/inSel1CUQ<1> swg: dh de
lay: 268.31ps (force) RC delay: 145.23ps
                                               lds: 32 pcap: 165.15ff
cap: 600.75ff (ext) m2len: 0.00 m3len: 2200.00 m4len: 2 156.00
        uu/UinstUQ/u21 (xbmux3dh16s 16S)
                                            Iport: SEL A0PEH<1>
Oport: q ad0ph IntDel: 114.00 net: UUinstUQ<21>
                                                       sw
g: dh delay: 263.67ps (force) RC delay: 96.44ps
                                                        lds: 2 pcap:
18.41ff cap: 466.33ff (ext) m2len: 0.00 m3len: 4072.00
m4len: 0.00
        rgxmit/Ura51RL/u2
                          (xbffdh24s 24S)
                                                        Iport: DO ADMPH
IntDel: 217.70
        Time through Path: 953.28
****
uu to at
****
Warning! Cycle time exceeded by 326.48ps using cycle time of 926.00 for
Iteration 1
            HARD ERROR 1059
    Path After Optimization using cycle time of 926.00:
       uu/UvldNoXcR11/u0
                               (xborffb3df32s 32S)
                                                        Oport: Q ADOPF
                                    swg: df delay: 621
IntDel: 86.50 net: UUvldNoXcR11_N
              RC delay: 261.60ps
                                       lds: 13 pcap: 114.39ff cap:
.74ps (force)
797.16ff (ext) m2len: 0.00 m3len: 6207.00 m4len: 0.00
        at/Uatpadcd/UvldNonNbSt_3/u0 (xbor14df32s 32S)
D6_A0PF Oport: Q_AND0PF IntDel: 224.30 net: at/Uatpadcd/v
ldNonNbSt N_3 swg: df delay: 32.94ps (force) RC delay: 2.54ps
lds: 2 pcap: 10.63ff cap: 74.83ff (ext) m2len: 0.00 m
3len: 331.00 m4len: 311.00
        at/Uatpadcd/UsrWrStb/u0 (xborff2dh2s 2S)
                                                                Iport:
DO AOPF IntDel: 287.00
        Time through Path: 1252.48
 NEXT SET IS SAME SIGMAL
p*
***
uu to cdio
* * * *
Warning! Cycle time exceeded by 256.25ps using cycle time of 926.00 for
Iteration 1 HARD ERROR 1190
    Path After Optimization using cycle time of 926.00:
      uu/UetaBffrdUT/u0
                              (xbffbdh24s 24S)
                                                      Oport: q andOph
                                   swg: dh delay: 875
IntDel: 89.20 net: UUetaUT_N<0>
.95ps (force) RC delay: 607.43ps lds: 9 pcap: 63.96
1176.06ff (ext) m2len: 0.00 m3len: 10110.00 m4len: 0.00
                                       lds: 9 pcap: 63.96ff
        cdio/UwrCtlAa/u0
                            (xbhrdh2s 2S)
                                                       Iport: DO ANDOPH
IntDel: 217.10
        Time through Path: 1182.25
****
uu to mc
***
arning! Cycle time exceeded by 256.25ps using cycle time of 926.00 for
Iteration 1 HARD ERROR 1189
    Path After Optimization using cycle time of 926.00:
```

uu/UetaBffrdUT/u0 (xbffbdh24s 24S) Oport: q andOph IntDel: 89.20 net: UUetaUT\_N<0> swg: dh delay: 875
.95ps (force) RC delay: 607.43ps lds: 9 pcap: 63.96ff
1176.06ff (ext) m2len: 0.00 m3len: 10110.00 m4len: 0.00 mc/u206/u0 (xbhrdh2s 2S) Iport: D0\_AND0PH IntDel: 217.10 Time through Path: 1182.25 \*\*\*\* uu to gt \*\*\* Warning! Cycle time exceeded by 958.02ps using cycle time of 926.00 for Iteration 1 HARD ERROR 1215 Path After Optimization using cycle time of 926.00: uu/UetaBffrdUT/u2 (xbffbdf32s 32S) Oport: Q ANDOPF IntDel: 89.50 net: UUetaUT\_N<2> swg: df delay: 128 2.12ps (force) RC delay: 794.83ps lds: 15 pcap: 90.22ff 1350.93ff (ext) m2len: 0.00 m3len: 11461.00 m4len: 0.00 gt/UgtSnake/UmuxCtl/Uahold\_1/u0 (xbor5df32s 32S) Iport: DO\_AOPF Oport: Q\_ANDOPF IntDel: 172.50 net: gt/UgtSnake/U muxCtl/ahold\_N\_1 swg: df delay: 59.60ps (force) RC delay: 5.88ps lds: 6 pcap: 34.73ff cap: 121.53ff (ext) m2len : 0.00 m3len: 66.00 m4len: 802.00 gt/UgtSnake/UmuxCtl/Uah1/u0 (xborff5dh8s 8S) Iport: D2 A0PF IntDel: 280.30 Time through Path: 1884.02 \*\*\*\* uu to dr \*\*\*\* Warning! Cycle time exceeded by 772.25ps using cycle time of 926.00 for Iteration 1 HARD ERROR 1234 Path After Optimization using cycle time of 926.00: uu/UetaBffrdUT/u2 (xbffbdf32s 32S) Oport: Q ANDOPF IntDel: 90.00 net: UUetaUT\_N<2> swg: df delay: 125
3.55ps (force) RC delay: 798.71ps lds: 15 pcap: 95.06ff cap: 1355.77ff (ext) m2len: 0.00 m3len: 11461.00 m4len: 0.00 (xbmuxff2dh3s 3S) dr/muxff2tag1/u1 Iport: SEL\_A0PEH<0> IntDel: 354.70 Time through Path: 1698.25 uu to au \*\*\* Warning! Cycle time exceeded by 48.46ps using cycle time of 926.00 for Iteration 1 HARD ERROR 1240 Path After Optimization using cycle time of 926.00: uu/UtauOutUU/u0 (xbffedh24s 24S) Oport: q\_adlph IntDel: 127.90 net: UUtauUU swg: dh delay: 559.26ps (force) RC lds: 16 pcap: 212.10ff cap: 1005.42ff (ext) delay: 393.15ps m2len: 0.00 m3len: 7212.00 m4len: 0.00 au/z00/u0 (xbffedh3s 3S) Iport: DO ANDMPH IntDel: 287.30 Time through Path: 974.46 \*\*\*\* uu to hz Warning! Cycle time exceeded by 49.79ps using cycle time of 926.00 for Iteration 1 HARD ERROR 1252 Path After Optimization using cycle time of 926.00: uu/UtauOutUU/u0 (xbffedh24s 24S) Oport: q\_and1ph IntDel: 127.90 net: UUtauUU\_N swg: dh delay: 560.59ps (force) RC delay: 394.28ps lds: 16 pcap: 212.10ff cap: 1006.74ff (ext)

Iport: DO ANDMPH hz/zzxx/u0 (xbffdh2s 2S) IntDel: 287.30 Time through Path: 975.79 \*\*\* uu to nb Warning! Cycle time exceeded by 49.79ps using cycle time of 926.00 for HARD ERROR 1253 Iteration 1 Path After Optimization using cycle time of 926.00: uu/UtauOutUU/u0 (xbffedh24s 24S) Oport: q\_and1ph IntDel: 127.90 net: UUtauUU\_N swg: dh delay: 560.59ps (force) RC delay: 394.28ps lds: 16 pcap: 212.10ff cap: 1006.74ff (ext) m2len: 0.00 m3len: 7224.00 m4len: 0.00 nb/hrbuf0/u0 (xbffedh2s 2S) Iport: DO ADMPH IntDel: 287.30 Time through Path: 975.79 \*\*\*\* iq to uu to rgxmit Warning! Cycle time exceeded by 13.42ps using cycle time of 926.00 for Iteration 1 HARD ERROR 1265 Path After Optimization using cycle time of 926.00: iq/UinstLQS/u8 (xbmuxffb8dh24s 24S) Oport: q\_ad0ph IntDel: net: IQinstQS<8> swg: dh delay: 371.94ps (f RC delay: 226.33ps lds: 1 pcap: 21.09ff cap: 712.11ff orce) (ext) m2len: 0.00 m3len: 6282.00 m4len: 0.00 

 uu/UinstUQ/u8
 (xbmux3dh16s 16S)
 Iport: D2\_AD0PH

 q\_and0ph IntDel: 74.00
 net: UUinstUQ\_N<8>
 swg: dh de

 lay: 186.18ps (force)
 RC delay: 55.49ps
 lds: 2 pcap: 1

 cap: 354.97ff (ext)
 m2len: 0.00 m3len: 3065.00 m4len: 0.00

 Iport: D2 AD0PH Oport: lds: 2 pcap: 17.82ff Iport: D0\_ANDMPH rgxmit/Urc51RL/ul (xbffdh24s 24S) IntDel: 217.70 Time through Path: 939.42 \*\*\*\* in hc0

m2len: 0.00 m3len: 7224.00 m4len: 0.00

Exhibit C10

\*\*\*\*

Bunch of errors

tbr

Sent:

Sunday, January 08, 1995 6:31 PM

To:

'geert (Geert Rosseel)'

Cc:

'billz'; 'brianl'; 'dickson'; 'geert'; 'hopper'; 'mws'; 'woody'

Subject:

Top-level Euterpe Timing errors

Follow Up Flag: Follow up

Flag Status:

Red

Geert Rosseel wrote (on Sun Jan 8):

Hi,

Here are the timing violations of the latest top-level run.

How does the total number compare to last time?

tbr (Tim B. Robinson)

Sent:

Sunday, January 08, 1995 6:31 PM

To:

Cc:

'geert (Geert Rosseel)'
'billz'; 'brianl'; 'dickson'; 'geert'; 'hopper'; 'mws'; 'woody'

Subject:

Top-level Euterpe Timing errors

Geert Rosseel wrote (on Sun Jan 8):

Ηi,

Here are the timing violations of the latest top-level run.

How does the total number compare to last time?

tbr

Sent:

Sunday, January 08, 1995 9:46 PM

To:

'Tom Eich'

Subject:

Pandora 1/6 meeting actions

Follow Up Flag: Follow up

Flag Status: Red

I think it would be worth posting your notes to pandora. Some things like the SIMM choice may provoke some discussion.

wampler (Kurt Wampler)

Sent:

Sunday, January 08, 1995 10:46 PM

To:

tom'

Cc:

'geert'; 'hopper'; 'ong'; 'vo'

Subject:

Re: widening power in clock spars?

#### Tom L. writes:

>Warren's examination of power distribution in euterpe found, among >other things, that the ends of the clock spars tend to be weak spots. >Although we're making other changes that may be adequate for euterpe, >it seems to me that, with modest effort, we could modify the clock/bias >construction to widen the clock shield wires into bigger power >distribution wires where there aren't actual clock wires to shield. >With the clock distribution scheme we have, this would give us >increasing vertical power bussing as one moved away from the mast -->ie, toward the spar ends.

>The only downside I can see to doing this is that we would lose the >ability for global routing to jog vertically in the clock spars. I >don't think this is a serious loss, though... in fact, I vaguely >remember we decided to disallow that completely anyway. Is this true?

Actually, the current routing strategy I'm working with permits jogging in the clock spars; the only thing that's disallowed is M3 under the power pad regions, to avoid long vertical wires which get hit repeatedly by many power pads.

These regions near the extreme ends of the clock spars are also used by the router to wire up the VFF\* custom domain bias signals, and we do have some extreme congestion in these regions near the north ends of spars 3 & 5. The VFF targets aren't easy to get to, and might be rendered unreachable if all the M3 resource were filled in with power bussing.

>To widen the M3 shield wires, I envision that a mask layer over the >clock distribution section of the clock spars (extending to just >include the outer shield wires) would be computed somehow (not sure >how, but it seems it shouldn't be too hard), then the clock/bias layout >would be post-processed by a vlsimm script. I think the following >script (which assumes the clock area mask is in the pseudo-layer >`clock\_area\_mask') would do the trick:

[sophisticated vlsimm script snipped]

### >Comments?

Let's examine the final Calliope route and see how the VFF hookups were made, and also to what extent global routing made use of these regions. We can also look at the current Euterpe route, but it doesn't yet have Cerberus or the VFF hookups in place. If it looks like we can do without those areas for routing, then I would support beefing up the power bussing in those areas (although it sounds like a fix to the hemming cell would address the problem identified by Warren). If it looks like these areas are useful for global routing, then I would be more reluctant to give them up, especially with the congestion we're grappling with in the north areas right now.

- Kurt

```
mws (Mark Semmelmeyer)
From:
                     Monday, January 09, 1995 3:56 AM
Sent:
                     'Geert Rosseel'
To:
                     'biliz (Bill Zuravleff)'; 'brianl (Brian Lee)'; 'dickson (Richard Dickson)'; 'hopper (Mark Hofmann)';
Cc:
                     'mws (Mark Semmelmeyer)'; 'tbr (Tim B. Robinson)'; 'woody (Jay Tomlinson)'
                     Re: Top-level Euterpe Timing errors
Subject:
> ****
> nb to uu : about 60 errors
> Warning! Cycle time exceeded by 354.80ps using cycle time of 926.00
Iteration 1
               HARD ERROR 53
      Path After Optimization using cycle time of 926.00:
          nb/nbctrl/Uareforreturn/u0
                                           (xborffb3df32s 32S)
                                                                    Oport:
Q_ADOPF
         IntDel: 88.00
                         net: nbWeDX1_N swg: df delay: 926
> .50ps (force)
                  RC delay: 484.28ps
                                          lds: 29 pcap: 139.27ff cap:
1078.56ff (ext) m2len: 0.00 m3len: 8539.00 m4len: 0.00
uu/UclrNbArryLBsyX2/u0 (xborff3df4s 4S)
                                                          Iport: D2_A0PF
IntDel: 266.30
          Time through Path: 1280.80
Bill has already taken out the buffer, but my conversion of this to half-swing isn't in
until my next release. Maybe I will need two copies as I have about 18-20 loads inside?
> Warning! Cycle time exceeded by 110.23ps using cycle time of 926.00
> for
               HARD ERROR 97
Iteration 1
      Path After Optimization using cycle time of 926.00:
          nb/ff 4 awa/u0 (xbffbdh24s 24S)
                                                   Oport: q andOph IntDel:
                                 swg: dh delay: 68.71ps (fo
        net: nb/awa_N<0>
89.60
         RC delay: 21.87ps
                                lds: 3 pcap: 49.91ff cap: 227.01ff
> rce)
(ext) m2len: 0.00 m3len: 1043.00 m4len: 728.00
                                   (xbbufdh32s 32S)
          nb/buf 4 NBawa/u0
                                                           Iport: DO_ANDMPH
Oport: q_ad0ph IntDel: 55.50 net: nbAWaR14<0>
          swg: dh delay: 645.61ps (force) RC delay: 461.89ps
                                                                    lds: 1
               cap: 1010.72ff (ext) m2len: 0.00 m3len:
pcap: 8.84ff
> 9108.00 m4len: 0.00
          uu/UnbAWaR15/u0 (xbffbdf8s 8S)
                                                   Iport: D0 ADMPH IntDel:
176.80
          Time through Path: 1036.23
This will be close, but if billz gives me a separate (from his
internals) flop copy without the buffer, I think it will make it.
> ****
> in uu : 400 errors
> Lot's of things like this : Can the mux be merged with the ff ??????
Yes, this is an oversight. I will fix it.
> ****
> uu to au : 40 errors
> Warning! Cycle time exceeded by 64.79ps using cycle time of 926.00
> for
                HARD ERROR 944
Iteration 1
      Path After Optimization using cycle time of 926.00:
         uu/UwrapAuLvaSelUXR0/u0 (xbhrdf32s 32S) Oport: Q AND0PF IntDel:
```

244.80 net: UUwrapAuLvaSelUXR0 N<0> swg: df delay: 256

```
> .19ps (force) RC delay: 87.14ps lds: 3 pcap: 2444.96ff (ext) m2len: 0.00 m3len: 3838.00 m4len: 0.00
                                              lds: 3 pcap: 22.78ff
            au/u202/u0
                            (xbor3dh32s 32S)
                                                       Iport: D1 A0PF Oport:
 q ad0ph IntDel: 138.20 net: au/sfrc14a_n
                                                       swg: dh de
 > lay: 5.57ps (force) RC delay: 0.32ps
                                                       lds: 1 pcap: 5.99ff
 cap: 27.59ff (ext) m2len: 0.00 m3len: 6.00 m4len: 210.0
 > 0
            au/u208/u0/u0
                              (xbmuxen2dh16s 16S)
                                                      Iport: SEL A0PEH<0>
 Oport: q_andOph IntDel: 118.90 net: au/u208/u0/m_N sw > g: dh delay: 10.93ps (force) RC delay: 0.28ps
                                                               lds: 1 pcap:
            cap: 26.95ff (ext) m2len: 0.00 m3len: 27.00 m4l
 8.85ff
 > en: 154.00
            au/u208/u0/u1
                           (xbffdf4s 4S)
                                                       Iport: DO ANDMPH
 IntDel: 216.20
            Time through Path: 990.79
 I think this was once a 2 tick path because uu sent it out of an hr.
 UU could decode the signal earlier so that the driving flop could be local. However,
 because a muxenff macro was used, it really is a "3 gate" path and is going to always
 remain a little stressed.
 > ****
 > uu to rgxmit
 > Warning! Cycle time exceeded by 27.28ps using cycle time of 926.00
 Iteration 1
                  HARD ERROR 1002
       Path After Optimization using cycle time of 926.00:
            uu/holduu/UinSel1CUQ 1/u0
                                              (xborffb7dh24s 24S)
 q_andOph IntDel: 89.60 net: uu/inSellCUQ<1> swg: dh de
 > lay: 268.31ps (force) RC delay: 145.23ps
                                                      lds: 32 pcap: 165.15ff
 cap: 600.75ff (ext) m2len: 0.00 m3len: 2200.00 m4len: 2
 > 156.00
                                                      Iport: SEL_A0PEH<1>
            uu/UinstUQ/u21 (xbmux3dh16s 16S)
 Oport: q_ad0ph IntDel: 114.00 net: UUinstUQ<21>
          _ad0ph IntDel: 114.00 net: UUinstUQ<21> sw delay: 263.67ps (force) RC delay: 96.44ps lds: 2 pcap:
           cap: 466.33ff (ext) m2len: 0.00 m3len: 4072.00
 18.41ff
 > m4len: 0.00
            rgxmit/Ura51RL/u2
                                      (xbffdh24s 24S)
                                                                Iport: DO ADMPH
 IntDel: 217.70
            Time through Path: 953.28
 My offer to geert still stands to send this (sometimes iq-->)uu-->rgxmit-->rgcr path
 without going through rgxmit.
 > ****
 > uu to at
 > Warning! Cycle time exceeded by 326.48ps using cycle time of 926.00
                HARD ERROR 1059
       Path After Optimization using cycle time of 926.00:
           uu/UvldNoXcR11/u0
                                  (xborffb3df32s 32S) Oport: Q AD0PF
 IntDel: 86.50 net: UUvldNoXcR11_N
                                            swg: df delay: 621
 > .74ps (force) RC delay: 261.60ps lds: 13 pcap: 3 797.16ff (ext) m2len: 0.00 m3len: 6207.00 m4len: 0.00
                                             lds: 13 pcap: 114.39ff cap:
> at/Uatpadcd/UvldNonNbSt_3/u0 (xbor14df32s 32S)
D6_A0PF Oport: Q_AND0PF IntDel: 224.30 net: at/Uatpadcd/v
> ldNonNbSt_N_3 swg: df delay: 32.94ps (force) RC delay: 2.54ps
 lds: 2 pcap: 10.63ff cap: 74.83ff (ext) m2len: 0.00 m
 > 3len: 331.00 m4len: 311.00
           at/Uatpadcd/UsrWrStb/u0 (xborff2dh2s 2S)
                                                                         Iport:
 D0_A0PF IntDel: 287.00
           Time through Path: 1252.48
 woody was hinting at a secret plan to fix this.
```

```
> ****
> iq to uu to rgxmit
> Warning! Cycle time exceeded by 13.42ps using cycle time of 926.00
> for
               HARD ERROR 1265
Iteration 1
      Path After Optimization using cycle time of 926.00:
          iq/UinstLQS/u8 (xbmuxffb8dh24s 24S)
                                                   Oport: q_adOph IntDel:
89.60
       net: IQinstQS<8>
                              swg: dh delay: 371.94ps (f
> orce) RC delay: 226.33ps lds: 1 pcap: 21.09ff (ext) m2len: 0.00 m3len: 6282.00 m4len: 0.00
                                                          cap: 712.11ff
          uu/UinstUQ/u8 (xbmux3dh16s 16S)
                                                   Iport: D2_ADOPH Oport:
q_and0ph IntDel: 74.00
                         net: UUinstUQ N<8>
                                                  swg: dh de
> lay: 186.18ps (force) RC delay: 55.49ps
                                                  lds: 2 pcap: 17.82ff
cap: 354.97ff (ext) m2len: 0.00 m3len: 3065.00 m4len: 0
          rgxmit/Urc51RL/u1
                                  (xbffdh24s 24S)
                                                            Iport: DO ANDMPH
IntDel: 217.70
          Time through Path: 939.42
My offer to geert still stands to send this (sometimes iq-->)uu-->rgxmit-->rgcr path
without going through rgxmit.
```

From: doi (Derek Iverson)

Sent: Monday, January 09, 1995 4:30 PM

To: 'tom (Tom Laidig)'

Cc: 'lisar'; 'geert (Geert Rosseel)'; 'Tim B. Robinson'

Subject: Re: BOM trouble

### Tom Laidig writes:

- > Tim B. Robinson writes:
- > |When I did agetbom in the proteus snapshot I got the following
- > warning:
- > | > |WARNING SUMMARY ------
- > /n/auspex/s23/euterpe-proteus-cp/ged/sc: Directory scxbcgdr1 is not part of the BOM (but still present locally)
- > I'll let doi comment on getbom's behavior (FYI, doi, that directory only
- > contained 4 files, all under cvs control). I have removed scxbcgdrl,
- > since it is, in fact, obsolete. It was deleted in BOM revision 45.0
- > dated 12/21:

Getbom was modified on 12/13/94 so that directories that were no longer mentioned in the BOM being extracted and were under CVS control (i.e. had a CVS directory) are not removed unless the -K option is used.

When 'chip' extracts stuff as a result of a releasebom, it uses the -K option.

Why? Tom Vo discovered that if you cvs add a directory (creates the CVS directory within the target directory) and then go about creating all sorts of source files (but have not yet `cvs added' them), a getbom at this point would remove all your source files.

Getbom tries real hard not to remove things it shouldn't so if a directory is supposed to be removed, it runs 'cvs status' on the entire subtree to make sure everyting is at least 'up-to-date' before removing it. As you might have already guessed, new files that have not been added to the repository look just like objects or intermediate files, so they are removed.

If you want this behaviour, you will have to use the -K option.

doi

ong (Warren R. Ong)

Sent:

Monday, January 09, 1995 6:16 PM

To:

'Kurt Wampler'

Cc:

'vanthof (Dave Van't Hof)'; 'geert (Geert Rosseel)'; 'rich (Rich McCauley)'; 'tbr (Tim B.

Robinson)'; 'vikki (Vikki Vu)'

Subject:

Re: Please Lock Down "iobyte0" & "ioquadctrl"

>From Kurt Wampler ... @ Warren Ong writes: @ -----

@ >Power Improvement has been done to the layouts of iobyte0 and @ >ioquadctrl. They have passed lvs and drc. Dave, please lock down @>@> iobyte0 @> ioquadctrl @>@>Since there are related cells that are generated by gards, perhaps @>they need to be re-routed - Kurt?

I've updated the /u/chip/ version of the ioquadstdc gardswart; it ര definitely

changed the routing, but it did route to completion. It's probably time

now to LVS iobyte and make sure that the whole cell is clean & selfæ

@ consistent. @

@ After iobyte passes LVS/DRC, I assume Tim will getbom these changes in euterpe's proteus snapshot and kick off a gardswart build in the snapshot.

They have passed drc and lvs after the latest route on Friday.

Warren.

Sent:

Monday, January 09, 1995 6:46 PM

To:

'abbott@MicroUnity.com'; 'agc@MicroUnity.com'

Cc:

'graham@MicroUnity.com'; 'hessam@MicroUnity.com'; 'jt@MicroUnity.com';

'pandora@MicroUnity.com'; 'tony@MicroUnity.com'; 'yves@aphrodite'

Subject:

Bandwidth Calculations for HighRes RGB display (was RE: Euterpe housing containing

SUMMARY: 108 MHz display uses about 25% of one thread for a feasable implementation using Euterpe/Calliope system architecture. Simulation of microarchitectural effects is warranted.

I have for a long time assumed that a high resolution RGB display would be the I/O (really O) device which had the highest bandwidth requirements. (2.4 Gb/sec ATM is about twice as much bandwidth per link, though.) The calculation below affirms that the Euterpe-Calliope architecture should permit a feasable implementation of an RGB display.

When all of the display is static, using a frame-buffer is a good approach. However, when only some of the display is static, using the

DRAM->Calliope copying avoids DRAM-to-DRAM copying for double-buffered

displays and scrolling windows. Scrolling a near-full-screen window in a frame's time on a frame-buffer actually requires three times the DRAM bandwidth of a DRAM->Calliope system. The non-frame buffer system also permits fully-animated dragging (and even resizing!) of

Run-length encoding of constant-color regions can significantly reduce the average bandwidth, whether for screen background, or blank regions at the end and between text lines. Also, text windows can be read from DRAM at 1-8 bits/pixel and expanded in Euterpe, further reducing average DRAM bandwidth. Window boundaries can cause a modest increase in average DRAM bandwidth.

1024\*1280\*72 Hz without blank and sync time requires 94 MHz average rate; 108 MHz is a reasonable peak pixel rate, though it's a little low for the resolution and refresh rate indicated, considering the blank and sync time used on other displays, causing a lower refresh rate, and/or fewer pixels. For example, NeXT's displays were 1130x832x68 Hz => 68 MHz average rate, with a 100 Mhz peak pixel rate. 108 Mhz is only 8% higher, while the number of pixels is about 40% higher and the refresh rate is 6% higher.

Presumably, the choice of pixel rate is a noise issue; I believe we could live with 108 MHz if we had to. Using the same margin between peak and average as the NeXT displays, we get a 73.4 MHz average displayable pixel rate. This assumes that generation of blanking and sync signals can be expressed either as run-length encoded or as mostly preset values in the Calliope buffer memory.

73.4 MHz \* 3 bytes/pixel yields a 220 MB/sec data rate. Hexlet loads and stores imply a copy rate of 13.8 Mhexlets/sec. This is about 5% of a 1.08 GHz single-threaded machine, or about 25% of one of the five threads of a pentathread machine, assuming the copy rate is limited by the store rate of 1 store/4 cycles. I'd conclude that that the assertion that this is CPU bound is weak.

However, the Hermes channel, which requires 12 cycles for a 8 byte write, becomes highly utilized: a 330 MB/sec raw data rate is required in the path from Euterpe to Calliope, using up 30% of the available bandwidth. Assuming the data comes from Mnemosyne memory, an additional 7.5% on each channel is used to transmit the Hermes read commands, making the outgoing Hermes channel that contains Calliope and 2 Mnemosynes 38% utilized. Depending upon whether the Calliope or Mnemosyne devices are reached first in the ring, this is the worst case (when Calliope comes first).

If Mnemosynes are first, the utilization reaches 43% as the 6-byte read commands are replaces with 10-byte read responses.

The return path utilization reaches only 17%, as most packets are then 2-byte write responses.

Calliope first: E----E 12% 14% 38% 178

Mnemosyne first:E----M----M-----E
38% 40% 43% 17%

Using Euterpe memory, the peak 400 MB/sec data rate of 100 MHz SDRAMs would be 55% utilized, which is uncomfortably high. (However, the use of page-mode can also be high, which compensates.) 4 Mnemosyne memories can provide memory bandwidth about twice as high, which brings memory utilization back below 30% peak/average. Much more (4x) bandwidth would be available from 4 Mnemosynes using SDRAMs.

With one thread issuing a store and a load every 20 cycles, the Hermes channel output must sustain 12+6 = 18 Hermes cycles at peak, so the details of the design of the NB load buffer are critical. In addition, this rate must match the capacity of Mnemosyne to accept the load operations to DRAM, which is also in the same ballpark figure: 1/4 of loads (distributing to the 4 Mnemosynes) each 80 cycles.

Simulation of real code is likely to be worthwhile, as there is substantial opportunity for microarchitecture interactions that could further limit performance. Notably, the gextract operation may be critical to realignment of data between DRAM and Calliope.

Regards, Craig

Sent:

Buffalo Chip [chip@rhea] Monday, January 09, 1995 7:14 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/gt BOM 67.0 initiated by woody completed @ Mon Jan 9 17:11:42
PST 1995 with exit status 0.. chip

Craig Hansen [craig@gaea.microunity.com]

Sent:

Subject:

Monday, January 09, 1995 7:46 PM

To:

'abbott@MicroUnity.com'; 'agc@MicroUnity.com'

Cc:

'graham@MicroUnity.com'; 'hessam@MicroUnity.com'; 'jt@MicroUnity.com';

'pandora@MicroUnity.com'; 'tony@MicroUnity.com'; 'yves@aphrodite'

Bandwidth Calculations for HighRes RGB display (was RE: Euterpe housing containing

Calliope)

SUMMARY: 108 MHz display uses about 25% of one thread for a feasable implementation using Euterpe/Calliope system architecture. Simulation of microarchitectural effects is warranted.

I have for a long time assumed that a high resolution RGB display would be the I/O (really O) device which had the highest bandwidth requirements. (2.4 Gb/sec ATM is about twice as much bandwidth per link, though.) The calculation below affirms that the Euterpe-Calliope architecture should permit a feasable implementation of an RGB display.

When all of the display is static, using a frame-buffer is a good approach. However, when only some of the display is static, using the

DRAM->Calliope copying avoids DRAM-to-DRAM copying for double-buffered

displays and scrolling windows. Scrolling a near-full-screen window in a frame's time on a frame-buffer actually requires three times the DRAM bandwidth of a DRAM->Calliope system. The non-frame buffer system also permits fully-animated dragging (and even resizing!) of

Run-length encoding of constant-color regions can significantly reduce the average bandwidth, whether for screen background, or blank regions at the end and between text lines. Also, text windows can be read from DRAM at 1-8 bits/pixel and expanded in Euterpe, further reducing average DRAM bandwidth. Window boundaries can cause a modest increase in average DRAM bandwidth.

1024\*1280\*72 Hz without blank and sync time requires 94 MHz average rate; 108 MHz is a reasonable peak pixel rate, though it's a little low for the resolution and refresh rate indicated, considering the blank and sync time used on other displays, causing a lower refresh rate, and/or fewer pixels. For example, NeXT's displays were 1130x832x68 Hz => 68 MHz average rate, with a 100 Mhz peak pixel rate. 108 Mhz is only 8% higher, while the number of pixels is about 40% higher and the refresh rate is 6% higher.

Presumably, the choice of pixel rate is a noise issue; I believe we could live with 108 MHz if we had to. Using the same margin between peak and average as the NeXT displays, we get a 73.4 MHz average displayable pixel rate. This assumes that generation of blanking and sync signals can be expressed either as run-length encoded or as mostly preset values in the Calliope buffer memory.

73.4 MHz \* 3 bytes/pixel yields a 220 MB/sec data rate. Hexlet loads and stores imply a copy rate of 13.8 Mhexlets/sec. This is about 5% of a 1.08 GHz single-threaded machine, or about 25% of one of the five threads of a pentathread machine, assuming the copy rate is limited by the store rate of 1 store/4 cycles. I'd conclude that that the assertion that this is CPU bound is weak.

However, the Hermes channel, which requires 12 cycles for a 8 byte write, becomes highly utilized: a 330 MB/sec raw data rate is required in the path from Euterpe to Calliope, using up 30% of the available bandwidth. Assuming the data comes from Mnemosyne memory, an additional 7.5% on each channel is used to transmit the Hermes read commands, making the outgoing Hermes channel that contains Calliope and 2 Mnemosynes 38% utilized. Depending upon whether the Calliope or Mnemosyne devices are reached first in the ring, this is the worst case (when Calliope comes first).

If Mnemosynes are first, the utilization reaches 43% as the 6-byte read commands are replaces with 10-byte read responses.

The return path utilization reaches only 17%, as most packets are then 2-byte write responses.

Calliope first: E----E 14% 178 12% 38%

Mnemosyne first:E----M-----C----E
38% 40% 43% 17%

Using Euterpe memory, the peak 400 MB/sec data rate of 100 MHz SDRAMs would be 55% utilized, which is uncomfortably high. (However, the use of page-mode can also be high, which compensates.) 4 Mnemosyne memories can provide memory bandwidth about twice as high, which brings memory utilization back below 30% peak/average. Much more (4x) bandwidth would be available from 4 Mnemosynes using SDRAMs.

With one thread issuing a store and a load every 20 cycles, the Hermes channel output must sustain 12+6 = 18 Hermes cycles at peak, so the details of the design of the NB load buffer are critical. In addition, this rate must match the capacity of Mnemosyne to accept the load operations to DRAM, which is also in the same ballpark figure: 1/4 of loads (distributing to the 4 Mnemosynes) each 80 cycles.

Simulation of real code is likely to be worthwhile, as there is substantial opportunity for microarchitecture interactions that could further limit performance. Notably, the gextract operation may be critical to realignment of data between DRAM and Calliope.

Regards, Craig

Tim B. Robinson [tbr@gaea.microunity.com]

Sent:

Monday, January 09, 1995 9:33 PM

To:

'Craig Hansen'

Cc:

'abbott@MicroUnity.com'; 'agc@MicroUnity.com'; 'graham@MicroUnity.com'; 'hessam@MicroUnity.com'; 'jt@MicroUnity.com'; 'pandora@MicroUnity.com';

'tony@MicroUnity.com'; 'yves@aphrodite'

Subject:

Bandwidth Calculations for HighRes RGB display (was RE: Euterpe housing containing

Calliope)

Craig Hansen wrote (on Mon Jan 9):

SUMMARY: 108 MHz display uses about 25% of one thread for a feasable

implementation using Euterpe/Calliope system architecture. Simulation of microarchitectural effects is warranted.

<snip>

1024\*1280\*72 Hz without blank and sync time requires 94 MHz average rate; 108 MHz is a reasonable peak pixel rate, though it's a little low for the resolution and refresh rate indicated, considering the blank and sync time used on other displays, causing a lower refresh rate, and/or fewer pixels. For example, NeXT's displays were 1130x832x68 Hz => 68 MHz average rate, with a 100 Mhz peak pixel rate. 108 Mhz is only 8% higher, while the number of pixels is about 40% higher and the refresh rate is 6% higher.

I think your peak rate is somewhat optimistic here. I am familiar with one system (I designed it :-) ) which was 1280\*1024\*60Hz and had a peak rate of 110MHz. That was a long time ago though and I think the trend to higher refresh rates is offset to some extent by better monitors with lower retrace time allowing a higher portion of the time to carry active video. Even so I think 108MHz will limit either the pixel count or the refresh rate. This would also depend on just how we intend to generate sync and blanking signals. Clearly the approach of our current design (and I think if we are honest, our architecturally pure approach) would have us move the problem to software and require additional in band data which in the extreme case would make the average equal to the peak.

Presumably, the choice of pixel rate is a noise issue; I believe we could live with 108 MHz if we had to. Using the same margin between peak and average as the NeXT displays, we get a 73.4 MHz average displayable pixel rate. This assumes that generation of blanking and sync signals can be expressed either as run-length encoded or as mostly preset values in the Calliope buffer memory.

I agree, all we really need is some minimal amount of framing information in the stream and simple hardware and fifo buffering can reconstruct the full signal.

# <snip again>

However, the Hermes channel, which requires 12 cycles for a 8 byte write, becomes highly utilized: a 330 MB/sec raw data rate is required in the path from Euterpe to Calliope, using up 30% of the available bandwidth. Assuming the data comes from Mnemosyne memory, an additional 7.5% on each channel is used to transmit the Hermes read commands, making the outgoing Hermes channel that contains Calliope and 2 Mnemosynes 38% utilized. Depending upon whether the Calliope or Mnemosyne devices are reached first in the ring, this is the worst case (when Calliope comes first). If Mnemosynes are first, the utilization reaches 43% as the 6-byte read commands are replaces with 10-byte read responses. The return path utilization reaches only 17%, as most packets are then 2-byte write responses.

Correction here. Write operations take 14 bytes, not 12, so the bandwidth needed is 385MB/s not 330.

Using Euterpe memory, the peak 400 MB/sec data rate of 100 MHz SDRAMs would be 55% utilized, which is uncomfortably high. (However, the use of page-mode can also be high, which compensates.) 4 Mnemosyne memories can provide memory bandwidth about twice as high, which brings memory utilization back below 30% peak/average. Much more (4x) bandwidth would be available from 4 Mnemosynes using SDRAMs.

With one thread issuing a store and a load every 20 cycles, the Hermes channel output must sustain 12+6=18 Hermes cycles at peak, so the details of the design of the NB load buffer are critical. In addition, this rate must match the capacity of Mnemosyne to accept the load operations to DRAM, which is also in the same ballpark figure: 1/4 of loads (distributing to the 4 Mnemosynes) each 80 cycles.

Can you clarify this please? First, I take 12+6 to really be 14+6 which exactly matches the 20 cycles in which you issued these.

However, I assume the thread is issuing hexlet loads and stores, where the Hermes channel ends up doing double the number of octlet transactions, so I'm not sure I see exactly what pattern you are expecting.

NB itself is capable of fully saturating the internal bus in Euterpe which connects it to the peripheral devices (Hermes channels plus DRAM). There, there is a 32 bit bus which takes 4 cycles to process each octlet transaction. This is a 50% overhead over the raw data and at 1080MHz is therefor 2.16GB/sec of real data. With simulated devices capable of absorbing this at full rate we have checked that every cycle does indeed get used.

However, the current Hermes channel interface design does not quite sustain the peak rate for issuing read requests. This is a tradeoff to keep the amount of buffering under control to save atoms. It will sustain one read every 8 cycles (transfering a 6 byte read request) and one write every 16 (transfering the 14 byte write request). (It's possible with the most recent design changes we have been able to plug this 2 byte gap on write transactions, but I need to check.) Note that for reads, the maximum sustained rate cannot be more than one in 10 cycles since we will be limited by the input channel bandwith and

eventually starve for sequence IDs. On the input side, the channel will handle sustained back to back responses at the full rate (as it must, since we do not control when devices decide to return responses).

For reference, the sustained throughput of a single Calliope (in the current implementation) is one transaction per 16 (Calliope) clocks. This is a result of the way the internal bandwidth is split in a fixed pattern between Hermes and the devices and between reads and writes (to control the noise spectrum). It can however support the peak rate on input, with the excess being buffered in a fifo.

Simulation of real code is likely to be worthwhile, as there is substantial opportunity for microarchitecture interactions that could further limit performance. Notably, the gextract operation may be critical to realignment of data between DRAM and Calliope.

Absolutely. We have seen major surprises in the past.

David Bulfer [dbulfer@gaea.microunity.com]

Sent:

Tuesday, January 10, 1995 10:37 AM

To:

'Tim B. Robinson'

Cc:

'Craig Hansen'; 'abbott@MicroUnity.com'; 'agc@MicroUnity.com'; 'graham@MicroUnity.com';

'hessam@MicroUnity.com'; 'jt@MicroUnity.com'; 'pandora@MicroUnity.com';

'tony@MicroUnity.com'; 'yves@aphrodite'

Subject:

Re: Bandwidth Calculations for HighRes RGB display (was RE: Euterpe housing containing

Calliope)

Here's a rule of thumb on calculating pixel clocks. There are many video spec's, but generally, you should allocate about 35% of your time to H and V blanking. For example,

Active area: 1280 x 1024
Refresh: 72 Hz
Active pixels: 1,310,720
Blanked pixels: 458,752

Virtual pixels: 1,769,472 Pixel clock: 127,401,984 Hz

In designing frame buffers, many people decouple the dot clock from the clock that writes the image into memory, especially with VRAM type designs. If so, you can write into memory at less than 100 MHz.

Hope this helps, David

David Bulfer

(\_) / (\_) \_-

email: dBulfer@MicroUnity.Com

\_

Phone: FAX: 408-734-8590 x282 408-734-8136 SnailMail: MicroUnity Systems

Engineering, Inc. 255 Caspian Drive Sunnyvale CA 94086

ken (Ken Hsieh)

Sent:

Tuesday, January 10, 1995 1:13 PM

To:

'sysadm'; 'tbr'

Subject: BudTool 4.3.1 Announcement

---- Begin Included Message -----

>From pbond@eng.pdc.com Tue Jan 10 11:11:40 1995

Date: Tue, 10 Jan 1995 11:10:20 +0800 From: pbond@eng.pdc.com (Phil Bond)

To: ken@MicroUnity.com

Subject: BudTool 4.3.1 Announcement

Cc: support@dm.eng.pdc.com X-Sun-Charset: US-ASCII Content-Length: 7246

Ken.

At your request, I am sending you a copy of the BudTool 4.3.1 announcement:

---- Begin Included Message -----

Date: Fri, 18 Nov 94

Dear Customer,

We are pleased to announce the BudTool 4.3.1 release is completed and will begin shipping today. All BudTool customers currently under their initial 90-day warranty and/or covered under a maintenance agreement are entitled to receive this upgrade free of charge.

Please call our customer service department at (510) 449-6881 or send an email to jlloyd@eng.pdc.com if you wish to receive the 4.3.1 upgrade. We will need you to include the following information:

- 1) Your name, company name and correct Fed Ex ship-to address (with mailstop)
- 2) Your phone number (in case we need to call you)
- 3) The platform, architecture and OS upon which BudTool will be upgraded
- 4) The type of drive or jukebox you are using
- 5) The version of BudTool from which you are upgrading\*
- 6) The distribution media you prefer (standard shipments will be on CD-ROM)
- \* Customers upgrading from BudTool 4.0.3 or 4.1 will need to upgrade first to BudTool 4.2.2 before upgrading to 4.3.1.

An overview of the new BudTool 4.3 features is provided below.

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

## **NEW BUDTOOL 4.3.1 FEATURES**

BudTool 4.3.1 offers extended media management features designed to reduce operator support time by up to 50%, along with other enhancements

summarized below.

## MEDIA MANAGEMENT

Improved method for specifying tape rotation/expiration within the backup expiration policies

Lets the system administrator specify retention time for each type of backup. When all backup images on a tape have expired, the tape is automatically returned to a logical free pool and is eligible to be overwritten. This eliminates complicated tape labeling schemes and guarantees that data will not be unexpectedly overwritten.

## Media location tracking

A media location field has been added to the tape's database which allows BudTool 4.3.1 to keep track of where each tape is located. During the file selection process in a retrieval, BudTool 4.3.1 identifies if a tape is stored in a jukebox, on-site or off-site.

## Media history

BudTool 4.3.1 can now keep track of how old a tape is and how many times the media has been reused. Reports can be generated that help to decide when to retire a tape and can reduce media errors caused by using old tapes.

# Migration path to bar code labeling schemes

For those wishing to convert from existing tape labeling schemes to bar code, a procedure has been documented and code developed to minimize the amount of labor associated with this transition.

## LARGE LIBRARY FEATURES

## Improved jukebox database initialization

The jukebox database is automatically maintained by scanning all of the tapes in the jukebox.

Automated maintenance of jukebox tape inventory sufficient for backup Determining if there are sufficient tapes in a jukebox to complete a backup and selecting which tapes to remove is a time-consuming task. This entire process has now been automated. BudTool 4.3.1 determines which tapes can be used for backups and if there are not enough tapes, it will determine which are the best tapes to remove from the jukebox. It will also produce a list of tapes to be recycled or list how many new tapes are required.

Automated re-arrangement of tapes to be exported from the library into a single bin-pack

BudTool 4.3.1 will now automatically move the tapes to be exported into contiguous locations in the library so whole bin-packs can be removed. This saves labor by eliminating the need for operators to search for tapes and reduces the opportunity for human error.

## Automated export of volumes

If the system administrator does not want to export bin-packs, BudTool 4.3.1 can automatically export tapes using the entry/exit port. Exported tapes can be replaced by new tapes selected from a suggested import list.

## **BARCODE**

## Enhanced barcode support

More extensive use of barcode labels makes it easier to keep track of large numbers of tapes and also reduces human error. This benefit is

primarily realized when used in jukeboxes with internal barcode scanners.

## Hand-held barcode scanner

Support for a hand-held barcode reader allows users to take advantage of barcode labels when the tapes are not in a library. The hand-held barcode scanner can be used when moving or retiring tapes. It can also be used to list the status, location and contents of a barcoded tape.

## Delayed initialization of tape

In jukeboxes with internal barcode scanners, the barcode is scanned and the tape is remembered as "blank" until used. Before the tape is used, its status as a blank tape is verified and the tape is labeled. This eliminates the time-consuming task of pre-labeling all new tapes.

## OFF-SITE BACKUPS

## Automated off-site copies

BudTool 4.3.1 can make a copy of all the backups required for a set of disaster recovery tapes. This allows you to keep one copy on-site for retrievals while saving another copy off-site for disaster recovery. The location of both tapes is maintained by BudTool 4.3.1.

## **SECURITY**

The backup server ("goserver") can optionally use the "rexec" system call to start a remote backup or retrieval

This eliminates the need for ".rhosts" entries on the clients which can lead to enhanced security.

The backup server has another new option for starting backup and retrieval operations on clients known as "proxy" backups

BudTool 4.3.1 can now back up machines that do not support "rsh".

#### DIAGNOSTICS

Significant improvements in the diagnostics and logging for BudTool's schedule daemon (btd) and the tape's database

Problems can more easily be traced to their source and the appropriate remedial action taken. Much of this work will be useful for a planned status monitor. Now, system administrators can easily develop their own status monitors.

## INSTALLATION

Enhanced BT Admin features improved tape labeling scheme, support for tape expiration dates and barcode labeling schemes

BT Admin can now generate tape labels with more detail which are more useful. These labels are now compatible with barcode tape labels. With BudTool 4.3.1, BT Admin can generate a set of schedules for each drive in a multi-drive library. BT Admin has also been modified to work with BudTool 4.3.1 media management features.

## **MISCELLANEOUS**

## Automatic drive cleaning

BudTool 4.3.1 will keep track of drive usage and automatically clean the drives at appropriate intervals.

## ANSI Standard tape format

A change in the BudTool 4.3.1 tape format makes it possible to maintain table-of-contents information without a special device driver. The new

| format uses ANSI standard format. |
|-----------------------------------|
|                                   |
| End Included Message              |
| End Included Message              |

Sent:

Tuesday, January 10, 1995 1:46 PM

To:

'software-checkins-dist'

Subject:

gnu-tools/sim/terp cycles.h

Update of /p/cvsroot/gnu-tools/sim/terp In directory calliope:/N/auspex/root/s6/lisa/src/gnu-tools/sim/terp

Modified Files:

cycles.h

Log Message:

"hide" name of thread pointer block variable in STALL\_THREAD\_DELAYED

Exhibit C10

From: lisar (Lisa Robinson)

Sent: Tuesday, January 10, 1995 3:43 PM

To: 'dickson'; 'woody'; 'mws'; 'biliz'; 'tbr'; 'jeffm'

Subject: gettst, stashtst

I have created 2 makefile targets, gettst and stashtst. They do pretty much the same as the shell scripts but they are a bit more flexible.

By default, they assume that you want to get the test from your verify tree in \$(CHIPROOT). To override just say: VERIFYROOT=/n/nosferatu/s2/euterpe or VERIFYROOT=/u/jeffm/chip/euterpe

By default the test got (!) is toplevel/5woody\_0. To override just say: TESTNAME=toplevel/test1\_0

So typically you would involke the make:

gmake gettst TESTNAME=toplevel/test1\_0 VERIFYROOT=/n/nosferatu/s2/euterpe

Most tests are released and built in /u/chip/euterpe/verify so you could point your verify there or to /n/nosferatu/s2/euterpe/verify

gmake stashtst to stash the test.

Hope this helps.

Lisa R.

Sent:

Buffalo Chip [chip@rhea] Tuesday, January 10, 1995 8:24 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/au BOM 26.0 initiated by dickson completed @ Tue Jan 10
18:20:12 PST 1995 with exit status 0.. chip

woody (Jay Tomlinson)

Sent:

Tuesday, January 10, 1995 9:59 PM

To:

'tbr' 'geert'

Cc: Subject:

hc performance enhancement

Tim,

I have a working version that appears to handle conflicts properly. It is quite a bit bigger, but still has loading and timing problems.

In /u/chip/euterpe/verilog/bsrc/hc/gards/hc0-pass1:

Atoms:

count atom bjt isrc pld clock

BJT Totals: 1359 11216 24187 16836 14532 7106

In local area with CYCLETIME=895 gards/hc0-pass1:

Atoms:
BJT Totals:

count atom bjt isrc pld clock 1496 15060 27638 24368 19632 7914

I have some ideas to reduce size, but nothing has been thought through yet.

Jay

wampler (Kurt Wampler)

Sent:

Tuesday, January 10, 1995 10:44 PM

To:

'geert'

Subject:

Re: New Euterpe toplevel

> I have a new Euterpe toplevel that has Cerberus in it. This is the complete

>chip .. nothing is missing .. Can you use this for more routing runs ?

I am interested to see how many additional Cerberus nets we have to deal with in the most congested areas. I suspect there will be significant perturbations to the placement before we have a complete solution, though. I'll pick up a copy of your latest files tomorrow if they will be stable until then.

Thanks,

Kurt

From: hopper (Mark Hofmann)

Sent: Wednesday, January 11, 1995 12:38 AM

To: 'Lisa Robinson'

Cc: 'tbr (Tim B. Robinson)'
Subject: Re: planet problem

# Lisa Robinson writes:

# Just tried compiling:

Running /n/nosferatu/s2/euterpe/tools/bin/espresso.mu...

Running /n/nosferatu/s2/euterpe/tools/bin/espresso.mu -Dso\_both...

Running /n/nosferatu/s2/euterpe/tools/bin/espresso.mu on output of /n/nosferatu/s2/euterpe/tools/bin/espresso.mu - Dso both...

Running /n/nosferatu/s2/euterpe/tools/bin/espresso.mu -Dopo...

Reg: tot=40 cube=17 max-AND-fanin=2 max-OR-fanin=1 max-fanin=2

Sob: tot=40 cube=24 max-AND-fanin=2 max-OR-fanin=1 max-fanin=2

SobReg: tot=40 cube=17 max-AND-fanin=2 max-OR-fanin=1 max-fanin=2

Opo: tot=40 cube=24 max-AND-fanin=2 max-OR-fanin=1 max-fanin=2

#### etc.

## Sorry

I did not look at may pager.

i can reproduce the bug.

I need to look at it a bit more.

i hope to have a fix for the 10am rleease.

thanks for putting the old version back.

-hopper

From: ken (Ken Hsieh)

Sent: Wednesday, January 11, 1995 11:58 AM

To: 'tbr

Cc: 'sysadm'

Subject: budtool test result

# Tim,

I have succeed in retriving a partation by using "request history" in budtool. (I said "media history" on the mail of yesterday.) It took 3 hours and 12 minutes to restore 1.5GB of data, /s32, from to tapes. It's acceptable. Also, it built right ownship and file/directory permission.

Ken

tbr

Sent:

Wednesday, January 11, 1995 12:02 PM

To:

'ken (Ken Hsieh)'

Cc:

'sysadm'

Subject:

budtool test result

Follow Up Flag: Follow up

\_\_\_\_\_\_

Flag Status:

Red

Ken Hsieh wrote (on Wed Jan 11):

Tim,

I have succeed in retriving a partation by using "request history" in budtool. (I said "media history" on the mail of yesterday.) It took 3 hours and 12 minutes to restore 1.5GB of data, /s32, from to tapes. It's acceptable. Also, it built right ownship and file/directory permission.

Great. Make some notes on the exact options/procedure in case someone else needs to run it next time.

fwo (Fred Obermeier) From: Wednesday, January 11, 1995 1:09 PM Sent: To: 'hardheads' 'fwo' Cc: More euterpe csyn possible errors. Subject: Ηi, A recent csyn run of tbr\_euterpe-passl.splvs with the partially implemented new Differential Input Swing check produced a few errors. The following errors should be of the class where differential inputs on a single gate are driven by complementary inputs coming from \_completely\_ \_different\_ driver cells. Please take a look at the following errors and let me know if this is ok or not. still working on debugging the DiffInputSwing check so these may or may not be false errors. Fred. excerpts from /u/fwo/chip.bsrc/euterpe/verilog/bsrc/SAVE/\*.csyn error (DiffInputSwingCheck.738) in file "tbr\_euterpe-pass1.splvs": drivers are non-diff or fail leaf-inp swing requirements Reason: drivers are non-diff or fail swing check diff inputs top.xauindxu132u0.auindx ga 1 instance path: instance path: top.xauindxu132u0.auindx\_gb\_n\_1 cellname path: top.xbffdf4s  $.d0_{admph}$ .d0\_andmph cellname path: top.xbffdf4s paired drivers instance path: top.xauindxu02au1.auindx ga 1 instance path: top.xauindxu02bul.auindx gb n 1 cellname path: top.xbor2df12s .q and0pf top.xbor2df12s cellname path: .q\_ad0pf paired topmost nets top.auindx\_ga\_1 instance path: instance path: top.auindx\_gb\_n\_1 cellname path: top.auindx ga 1 cellname path: top.auindx gb n 1 Reason: drivers are non-diff or fail swing check diff inputs top.xauindxu128u0.auindx ga 2 instance path: instance path: top.xauindxu128u0.auindx gb n 2 cellname path: top.xbffdf4s .d0 admph top.xbffdf4s .d0\_andmph cellname path: paired drivers top.xauindxu02au2.auindx\_ga\_2 instance path: top.xauindxu02bu2.auindx\_gb\_n\_2 instance path: cellname path: top.xbor2df12s .q and0pf cellname path: top.xbor2df6s .q\_ad0pf paired topmost nets instance path: top.auindx\_ga\_2 instance path: top.auindx gb n 2 top.auindx ga 2 cellname path: cellname path: top.auindx\_gb\_n\_2

Reason: drivers are non-diff or fail swing check

top.xauindxu123u0.auindx ga 3

top.xauindxu123u0.auindx\_gb\_n\_3 top.xbffdf4s .d0 admph

Exhibit C10

diff inputs

instance path:

instance path:

cellname path:

```
top.xbffdf4s
                                       .d0_andmph
  cellname path:
paired drivers
                     top.xauindxu02au3.auindx ga 3
  instance path:
  instance path:
                     top.xauindxu02bu3.auindx gb n 3
  cellname path:
                     top.xbor2df8s
                                       .q_and0pf
  cellname path:
                     top.xbor2df8s
                                       .q_ad0pf
paired topmost nets
  instance path:
                     top.auindx ga 3
  instance path:
                     top.auindx_gb_n_3
  cellname path:
                     top.auindx_ga_3
  cellname path:
                     top.auindx_gb_n_3
Reason: drivers are non-diff or fail swing check
diff inputs
                     top.xauindxull7u0.auindx ga 4
  instance path:
  instance path:
                     top.xauindxu117u0.auindx gb n 4
                                       .d0 admph
  cellname path:
                     top.xbffdf4s
                                       .d0_andmph
  cellname path:
                     top.xbffdf4s
paired drivers
                     top.xauindxu02au4.auindx_ga_4
  instance path:
  instance path:
                     top.xauindxu02bu4.auindx gb n 4
  cellname path:
                     top.xbor2df8s
                                      .q and0pf
                     top.xbor2df6s
  cellname path:
                                       .q_ad0pf
paired topmost nets
                     top.auindx_ga_4
  instance path:
  instance path:
                     top.auindx_gb_n_4
                     top.auindx_ga_4
  cellname path:
  cellname path:
                     top.auindx_gb_n_4
Reason: drivers are non-diff or fail swing check
diff inputs
                     top.xmcu02ms13u0.mc u02 op1 5
  instance path:
  instance path:
                     top.xmcu02ms13u0.mc u02 op2 n 5
  cellname path:
                     top.xbffdf24s
                                      .d0_admph
                     top.xbffdf24s
  cellname path:
                                      .do andmph
paired drivers
  instance path:
                     top.xmcu02opcodu5.mc_u02_op1_5
  instance path:
                     top.xmcu02opcd5u0.mc_u02_op2_n_5
  cellname path:
                     top.xbffbdf16s
                                       .q_ad0pf
  cellname path:
                     top.xbffbdf16s
                                       .q and0pf
paired topmost nets
  instance path:
                     \texttt{top.mc}\_\texttt{u02}\_\texttt{op1}\_\texttt{5}
  instance path:
                     top.mc_u02_op2_n_5
  cellname path:
                     top.mc u02 op1 5
  cellname path:
                     top.mc_u02_op2_n_5
Reason: drivers are non-diff or fail swing check
diff inputs
                     top.xifeuifphb3u0.ife_ifpovrlyr2_12
  instance path:
  instance path:
                     top.xifeuifphb3u0.ife_pclob2_12
  cellname path:
                     top.xbffdh4s
                                       .d0_admph
                                       .do andmph
  cellname path:
                     top.xbffdh4s
paired drivers
  instance path:
                     top.xifeuifpovrlyb2u0.ife ifpovrlyr2_12
  instance path:
                     top.xifeupclob2u10.ife_pclob2_12
  cellname path:
                     top.xbor2df4s
                                           .q_and0pf
  cellname path:
                     top.xbffdf4s
                                        .q_ad0pf
paired topmost nets
  instance path:
                     top.ife_ifpovrlyr2_12
  instance path:
                     top.ife_pclob2_12
  cellname path:
                     top.ife_ifpovrlyr2_12
  cellname path:
                     top.ife_pclob2_12
Reason: drivers are non-diff or fail swing check
diff inputs
                     top.xifeuifphb3u1.ife_ifpovrlyr2 13
  instance path:
  instance path:
                     top.xifeuifphb3u1.ife_pclob2_13
                     top.xbffdh4s
                                      .d0_admph
  cellname path:
```

```
top.xbffdh4s
                                      .d0_andmph
  cellname path:
paired drivers
                    top.xifeuifpovrlyb2ul.ife_ifpovrlyr2_13
  instance path:
  instance path:
                    top.xifeupclob2u11.ife_pclob2_13
  cellname path:
                    top.xbor2df4s
                                          .q and0pf
  cellname path:
                                       .q_ad0pf
                    top.xbffdf4s
paired topmost nets
  instance path:
                    top.ife_ifpovrlyr2_13
  instance path:
                    top.ife pclob2 13
  cellname path:
                    top.ife ifpovrlyr2 13
  cellname path:
                    top.ife_pclob2_13
Reason: drivers are non-diff or fail swing check
diff inputs
  instance path:
                    top.xifeuifphb3u2.ife_ifpovrlyr2_14
  instance path:
                    top.xifeuifphb3u2.ife_pclob2_14
  cellname path:
                    top.xbffdh4s
                                     .d0_admph
                                      .d0_andmph
  cellname path:
                    top.xbffdh4s
paired drivers
                    top.xifeuifpovrlyb2u2.ife_ifpovrlyr2_14
  instance path:
  instance path:
                    top.xifeupclob2u12.ife_pclob2_14
  cellname path:
                    top.xbor2df4s
                                         .q and0pf
  cellname path:
                    top.xbffdf4s
                                       .q_ad0pf
paired topmost nets
  instance path:
                    top.ife_ifpovrlyr2_14
                    top.ife_pclob2_14
  instance path:
  cellname path:
                    top.ife_ifpovrlyr2_14
                    top.ife pclob2_14
 cellname path:
```

Sent:

mws (Mark Semmelmeyer) Wednesday, January 11, 1995 1:29 PM

To:

'fwo'

Cc:

'hardheads'

Subject:

Re: More euterpe csyn possible errors.

The ife errors were real and are fixed in ife.V 1.37. They would have eventually been found by functional tests for ICache and/or trying more varied code branch target addresses (hopefully).

wingard (Drew Wingard)

Sent:

Wednesday, January 11, 1995 2:29 PM

To:

'fwo'; 'mws' 'hardheads'

Cc: Subject:

Re: More euterpe csyn possible errors.

#### Mws writes:

- > The ife errors were real and are fixed in ife.V 1.37.
- > They would have eventually been found by functional tests for ICache
- > and/or trying more varied code branch target addresses (hopefully).

I don't have the ife errors in front of me, but I wonder how functional testing would catch them.

The perceived importance of this new 'phase' of differential swing checks is due to our understanding that existing functional models ignore the 'complemented' half of all differential inputs. If this is true, then functional test are unable to detect problems resulting from connecting differential inputs to the outputs of cells which generate different logical signals.

For instance, connecting the differential data inputs of a ff to busa\_ad0ph and busb\_and0ph is electrically incorrect (makes a great

metastability test!) but would pass functional testing that ignored the complemented input as long as the intended function was to delay busa by one clock cycle.

This is a check that we thought csyn was performing all along. Oops. I believe that Fred is going to test Calliope once he has the check fully implemented.

Of course, folks who make heavy use of the Verilog macros (D(), etc) are not likely to have problems like this. A situation where we are vulnerable is when someone copies a block of Verilog which calls out the inputs separately and then changes the output and true input names, but overlooks the complemented inputs.

Drew

mws (Mark Semmelmeyer)

Sent:

Wednesday, January 11, 1995 2:36 PM

To:

'fwo'; 'wingard' 'hardheads'

Cc: Subject:

Re: More euterpe csyn possible errors.

- > From wingard Wed Jan 11 12:29:00 1995
- > Mws writes:
- >> The ife errors were real and are fixed in ife.V 1.37.
- > > They would have eventually been found by functional tests for ICache
- > > and/or trying more varied code branch target addresses (hopefully).
- > I don't have the ife errors in front of me, but I wonder how
- > functional testing would catch them.

Your explanation of misconnected differential inputs intended to be differential is correct. My particular case is observable functionally because the 2 inputs were supposed to be ORed together, not just 1 of them staged. Because an orff2 and ff have the same number and types of ports, normal port mismatch checks don't catch it like it would for a differential OR or a wider famin OR.

tbr

Sent:

Wednesday, January 11, 1995 3:50 PM

To:

'lisar'; 'jeffm'

Subject:

forwarded message from Mark Semmelmeyer

Follow Up Flag: Follow up

Red

Would be worth understanding what it would have taken to see this.

----- Start of forwarded message -----

Return-Path: <mws>

Flag Status:

Received: from clytemnestra.microunity.com by gaea.microunity.com (4.1/muse1.3)

id AA22413; Wed, 11 Jan 95 11:33:10 PST

Received: from localhost by clytemnestra.microunity.com (8.6.4/muse-sw.3)

id LAA01042; Wed, 11 Jan 1995 11:29:07 -0800

Message-Id: <199501111929.LAA01042@clytemnestra.microunity.com>

From: mws (Mark Semmelmeyer)

To: fwo Cc: hardheads

Subject: Re: More euterpe csyn possible errors.

Date: Wed, 11 Jan 1995 11:29:07 -0800

The ife errors were real and are fixed in ife.V 1.37. They would have eventually been found by functional tests for ICache and/or trying more varied code branch target addresses (hopefully).

----- End of forwarded message -----

doi (Derek Iverson)

Sent:

Wednesday, January 11, 1995 6:30 PM

To:

'sandeep'; 'guarino'; 'gmo'; 'jeffm'; 'wayne'; 'doi'; 'jerry'; 'iimura'

Cc:

Subject:

Software Bringup Meeting Minutes - January 11, 1995

Software Bringup Meeting

January 11, 1995

Next Meeting:

January 18 at 10:00 am.

Attendees: jeffm, guarino, gmo, sandepp, doi

New Action Items

Item: Rerun dcacheharder test and get cycle count results.

Status: [01/11] New.

The previous run of dcacheharder didn't have the proper configuration

Item: More investigation on CBI and workstation interface issues.

Who: guarino, wayne

Need to get further details on the hardware modifictions that wayne discusses at a previous meeting that would allow for the cerberus clock to be free-running as long as there was no activity on the bus (wayne).

Lorreta is going to investigate the possibility of figuring out how to interface to the parallel port hardware on the sgi.

Review of Action Items

Item: Implement parallel port device driver for Linux on PC.

Who: jerry, doi

Status: [12/14] In progress.

Item: Define and implement a snapshot environment for the HW and SW

simulators. Who: jeffm, gmo

[11/30] In progress Status:

> The IKOS simulator isn't as easy to load and restore state as we had previously thought.

Jeff is finishing his list of high-level thoughts on how we can

achieve a snap-shot environment.

Item: Continue trying to find either source code for parallel drivers

or descriptions of hardware so we can write out own.

gmo sgi machines Who: doi sun machines

[11/23] progress continues (although not much). Status:

The never ending item.....

Derek will call Avcom to get more information about Sun drivers.

Item: Build scripting/UI capabilities above gdb for regression tests.

Who: doi

Status: on hold until the the boot, gdb boot stub, and virtual devices

are complete. (estimated start date of 1/10)

Start date may be the end of this week (01/13).

Item: Create performance test plan

Who: jeffm, guarino

Status: [11/30] In progress.

We continue to run tests to help us compare terp vrs hardware

performance.

We still need to put together the actual performance tests that

need to be run on the hardware.

Item: Add Unix-like tests to software acceptance tests.

Who: iimura

Status: [11/30] In progress.

Any day now...

Item: Simulator needs to understand `reset'

Who: gmo

Status: [11/30] In progress. Target finish of 1/20.

Item: Implement and bring-up boot, gdb boot stub, and virtual device

support on the software simulator.

Who: sandeep/gmo

Status: in progress (delayed until 1/10 from original target of 12/23)

A couple days delay... Mostly on track.

Completed Items

Item: Get cycle counts of kernel tests to jeffm

Who: guarino

Status: [12/14] Done.

Test Status

synctest has run.

Sent:

graham (Graham Y. Mostyn) Wednesday, January 11, 1995 7:05 PM

To:

'dbulfer'

Cc: Subject:

'pandora'; 'graham' Pandora clock

Dave -

The problem to be solved is the clocking arrangement of a Pandora system that carries a Calliope module (which must necessarily carry its own low-jitter 1080MHz clock for RF applications, and to which is locked all digital logic in the Hestia design).

Is it feasible - in those applications - to omit or disconnect the new 54MHz Euterpe clock that you are building for an all-digital application, and feed a 54MHz clock from a Calliope module across the backplane?

Regards, Graham.

dbulfer (David Bulfer)

Sent:

Wednesday, January 11, 1995 7:53 PM

To:

'Graham Y. Mostyn'

Cc:

'pandora'; 'graham (Graham Y. Mostyn)'

Subject:

Re: Pandora clock

```
> Dave -
> The problem to be solved is the clocking arrangement of a Pandora
> system that carries a Calliope module (which must necessarily carry
> its own low-jitter 1080MHz clock for RF applications, and to which is
> locked all digital logic in the Hestia design).
>
> Is it feasible - in those applications - to omit or disconnect the new
> 54MHz Euterpe clock that you are building for an all-digital
> application, and feed a 54MHz clock from a Calliope module across the
> backplane?
>
> Regards, Graham.
```

We plan on having a clock distribution system that will broadcast identical copies of the clock to all modules (where is may or may not be used). A good solution is to have the Calliope module connect its clock over a shielded-twistd pair cable to clock distribution board.

This would permit the maximum flexibility of physical location for Calliope while maintaining signal integrity and not burdening the connectors.

David

```
From:
                     tbr
  Sent:
                     Wednesday, January 11, 1995 7:58 PM
  To:
                     'lisar'
                     vhdl problem
  Subject:
  Follow Up Flag: Follow up
                     Red
  Flag Status:
We found it. The original was:
entity i_euterpe_wrap is
    port (
         poko
                     in: std logic;
                     out: std_logic_vector (63 downto 0);
         rdata
         sdclock0_abm out: std_logic;
                       out: std_logic_vector (4 downto 0);
         sdc abm
         sda abm
                       out: std_logic_vector (12 downto 0);
         sdd abm
                       inout: std_logic_vectore (31 downto 0)
end i_euterpe_wrap;
It should be:
entity i_euterpe_wrap is
    port (
                     : in std_logic;
         poko
                     : out std_logic_vector (63 downto 0);
         rdata
         sdclock0_abm : out std_logic;
                      : out std_logic_vector (4 downto 0);
         sdc abm
                       : out std_logic_vector (12 downto 0);
         sda abm
         sdd abm
                       : inout std_logic_vector (31 downto 0)
end i_euterpe_wrap;
```

For some reason it compiled it with nothing. According to Pat, the default is in, so that should not account for it. However, he says that if we bring it up to the vhdl level, and connect a net to it, it will put in a driver that will clash with the driver from the stimulus. So I think we need to remove poke from the wrapper interface.

fwo (Fred Obermeier)

Sent:

Wednesday, January 11, 1995 8:07 PM

To:

'hardheads'

Cc:

'fwo'

Subject:

Re: More euterpe csyn possible errors.

## Drew wrote:

> I believe that Fred is going to test Calliope once he has the check fully

> implemented.

I couldn't wait to see if there might be a problem with Calliope.

The current limited version of the differential input swing check didn't find any problem with the snap-shot version:

/n/auspex/s30/calliope/verilog/src/small\_calliope-iter.splvs

Only the error messages relate to the Old Style phase checks as reported by previous runs. I'll rerun again once this test is completely implemented.

Fred.

tbr (Tim B. Robinson)

Sent:

Wednesday, January 11, 1995 8:17 PM

To:

'graham (Graham Y. Mostyn)'

Cc:

'dbulfer'; 'graham'; 'pandora'

Subject:

Pandora clock

Graham Y. Mostyn wrote (on Wed Jan 11):

Dave -

The problem to be solved is the clocking arrangement of a Pandora system that carries a Calliope module (which must necessarily carry its own low-jitter 1080MHz clock for RF applications, and to which is locked all digital logic in the Hestia design).

Is it feasible - in those applications - to omit or disconnect the new 54MHz Euterpe clock that you are building for an all-digital application, and feed a 54MHz clock from a Calliope module across the backplane?

Yes, the 54 MHz source would be on the "herminator" that you would remove to attach the calliope module to hermes.

tbr

Sent:

Wednesday, January 11, 1995 8:19 PM

To:

'fwo (Fred Obermeier)'

Cc:

'fwo'; 'hardheads'

Subject:

Re: More euterpe csyn possible errors.

Follow Up Flag: Follow up

Flag Status:

Red

Fred Obermeier wrote (on Wed Jan 11):

#### Drew wrote

> I believe that Fred is going to test Calliope once he has the check fully

> implemented.

I couldn't wait to see if there might be a problem with Calliope. The current limited version of the differential input swing check didn't find any problem with the snap-shot version: /n/auspex/s30/calliope/verilog/src/small\_calliope-iter.splvs Only the error messages relate to the Old Style phase checks as reported by previous runs. I'll rerun again once this test is completely implemented.

Phew!

Thanks

tbr (Tim B. Robinson)

Sent:

Wednesday, January 11, 1995 8:19 PM

To:

'fwo (Fred Obermeier)'

Cc:

'fwo'; 'hardheads'

Subject:

Re: More euterpe csyn possible errors.

Fred Obermeier wrote (on Wed Jan 11):

## Drew wrote:

- > I believe that Fred is going to test Calliope once he has the check fully
- > implemented.

I couldn't wait to see if there might be a problem with Calliope. The current limited version of the differential input swing check didn't find any problem with the snap-shot version:

/n/auspex/s30/calliope/verilog/src/small\_calliope-iter.splvs Only the error messages relate to the Old Style phase checks as reported by previous runs. I'll rerun again once this test is completely implemented.

Phew!

Thanks Tim

Tom Eich [tbe@MicroUnity.com]

Sent:

Wednesday, January 11, 1995 9:55 PM

To:

'Tim B. Robinson'

Cc:

'graham@MicroUnity.com'; 'jt@MicroUnity.com'; 'pandora@MicroUnity.com'

Subject:

Re: Analog modul form factor

>I thought of a possibel soution to having a larger form factor for the >analog modules. Suppose we mounter the analog board horizonatally and >use a flexible cable connection to connect to the hermes connector on >the backplane. This would allow a board of whatever width you needed >with full access at the rear/front panel for connectors. >When this module is not required, the same hermes slot would of course >still accept a small form factor (digital?) module.

I think I understand what you mean here, but have a concern with airflow management that I'll have to describe with a drawing. I'll try to stop by.

>I'm no good at doing those cute ascii diagrams some people like to put >in email, so if the above makes no sense please catch me near a white >board.

This afternoon met with Graham, Jean-Yves, Tony and Grant to go over analog sizing and packaging issues, and concluded that there is probably adequate pcb area within a Euterpe sized module given Euterpe heat sink size vs.

Calliope heat sink size. I am working on a module layout for completion by week's end, and will review with appropriate parties before then.

> >Tim

-Tom

Tom Eich MicroUnity Systems Engineering, Inc. 255 Caspian Dr. Sunnyvale, CA 94089 (408)734-8100, (408)734-8136 fax tbe@microunity.com

tbr

Sent:

Wednesday, January 11, 1995 10:24 PM

To:

'Tom Eich'

Cc:

'graham'; 'jt'; 'pandora'

Subject:

Re: Analog modul form factor

Follow Up Flag: Follow up

Flag Status:

Red

# Tom Eich wrote (on Wed Jan 11):

>I thought of a possibel soution to having a larger form factor for the >analog modules. Suppose we mounter the analog board horizonatally >and use a flexible cable connection to connect to the hermes connector >on the backplane. This would allow a board of whatever width you >needed with full access at the rear/front panel for connectors. >When this module is not required, the same hermes slot would of course >still accept a small form factor (digital?) module.

I think I understand what you mean here, but have a concern with airflow management that I'll have to describe with a drawing. I'll try to stop by.

Never said it would be easy! It is a problem because the calliope would have to be on the big board to avoid the the connector transitions that make a multi-board small form factor soultion unattractive. If that were no problem, annother arrangement would have a rigid connection to the backplane which could itself carry the calliope with similar air manage\ment to normal modules.

>I'm no good at doing those cute ascii diagrams some people like to put >in email, so if the above makes no sense please catch me near a white >board.

>

This afternoon met with Graham, Jean-Yves, Tony and Grant to go over analog sizing and packaging issues, and concluded that there is probably adequate pcb area within a Euterpe sized module given Euterpe heat sink size vs. Calliope heat sink size. I am working on a module layout for completion by week's end, and will review with appropriate parties before then.

OK. If we can fit it that way it's clearly preferable to my suggestion.

tbr (Tim B. Robinson)

Sent:

Wednesday, January 11, 1995 10:24 PM

To:

'Tom Eich'

Cc: Subject: 'graham'; 'jt'; 'pandora' Re: Analog modul form factor

Tom Eich wrote (on Wed Jan 11):

>I thought of a possibel soution to having a larger form factor for the >analog modules. Suppose we mounter the analog board horizonatally >and use a flexible cable connection to connect to the hermes connector >on the backplane. This would allow a board of whatever width you >needed with full access at the rear/front panel for connectors. >When this module is not required, the same hermes slot would of course >still accept a small form factor (digital?) module.

I think I understand what you mean here, but have a concern with airflow management that I'll have to describe with a drawing. I'll try to stop by.

Never said it would be easy! It is a problem because the calliope would have to be on the big board to avoid the the connector transitions that make a multi-board small form factor soultion unattractive. If that were no problem, annother arrangement would have a rigid connection to the backplane which could itself carry the calliope with similar air manage \ment to normal modules.

>I'm no good at doing those cute ascii diagrams some people like to put >in email, so if the above makes no sense please catch me near a white >board.

This afternoon met with Graham, Jean-Yves, Tony and Grant to go over analog sizing and packaging issues, and concluded that there is probably adequate pcb area within a Euterpe sized module given Euterpe heat sink size vs. Calliope heat sink size. I am working on a module layout for completion by week's end, and will review with appropriate parties before then.

OK. If we can fit it that way it's clearly preferable to my suggestion.

hopper (Mark Hofmann)

Sent:

Thursday, January 12, 1995 12:20 AM

To:

'billz (Bill Zuravleff)'; 'geert (Geert Rosseel)'

Cc: Subject:

nb status

Ηi,

I'm not sure what's happened but the NB placement that I've checked in iterates 10 times and does not make timing. I \_thought\_ that I had a placement that iterated 7 times and did converge. Unfortunately, I lost the source of this placement in the auspex crash, but I also thought that I had re-created it successfully.

At any rate, the version that is now checked in runs the same in /u/chip as my home area and does not converge. I will try to look at the results but please feel free to look at them as well.

In my area the makefile output is

~hopper/chip/euterpe/verilog/bsrc/nb/out

for /u/chip it is:

/n/tmp/chiplog/hopper.tomato.19211.euterpe-verilog-bsrc-nb

-thanks, hopper

thanks, mark hofmann hopper@microunity.com 408 734 8100 From: geert (Geert Rosseel)

Sent: Thursday, January 12, 1995 10:24 AM

To: 'tbr'

Subject: Euterpe top level

Hi Tim,

I build a toplevel euterpe with cerberus in it . I will do an update today and build the next one if I am up to it.

Geert

From: geert (Geert Rosseel)

Sent: Thursday, January 12, 1995 10:30 AM

To: 'tom'

Cc: 'lisar'; 'tbr'; 'wingard' Subject: Two new databases

## Hi Tom,

Can you install two new databases:

- 1. CMOS-proteus: common database for CMOS design style chips
- 2. CMOS-euterpe : database for CMOS euterpe

You are free to choose the names as you wish ..

We've decided to start a new proteus for the CMOS stuff ....

I probably will not be in this week, but can you and Drew further discuss the issue of how to deal with different processes in the schematics?

Thank's

Geert

wampler (Kurt Wampler)

Sent:

Thursday, January 12, 1995 10:48 AM

To:

'geert'

Subject:

Re: Euterpe

> Hi Kurt, did you get the latest Euterpe. I'd like to build the next one.

>Geert

I didn't pick it up; other things came up yesterday with mask vendors and gardswarts. We did continue to study the prior placement, however, and extract more information from it.

Go ahead and commence the build of the next one and I'll pick it up once the source files are ready.

I believe mws, billz, dickson & I plan to have a follow-up meeting with tbr today to review the results of their study; it looks like some fairly significant changes in placement are warranted, and possibly a baseplate/ floorplan change. If you make it in today, this is something you should definitely be involved in.

- Kurt

tbr

Sent:

Thursday, January 12, 1995 11:13 AM

To:

'geert (Geert Rosseel)'

Subject:

Euterpe top level

Follow Up Flag: Follow up

Flag Status:

Red

Geert Rosseel wrote (on Thu Jan 12):

Hi Tim,

I build a toplevel euterpe with cerberus in it . I will do an update today and build the next one if I am up to it.

OK. Billz has determined that we should be able to fix the left side routing problem if we can move LTLB down. We seem to have a lot of space around UU. Is that realistic or had you powered it down some way in the last run?

tbr (Tim B. Robinson)

Sent:

Thursday, January 12, 1995 11:13 AM

To:

'geert (Geert Rosseel)'

Subject:

Ĕuterpe top level

Geert Rosseel wrote (on Thu Jan 12):

Hi Tim,

I build a toplevel euterpe with cerberus in it . I will do an update today and build the next one if I am up to it.

OK. Billz has determined that we should be able to fix the left side routing problem if we can move LTLB down. We seem to have a lot of space around UU. Is that realistic or had you powered it down some way in the last run?

stick (Bruce Bateman)

Sent:

Thursday, January 12, 1995 12:25 PM

To:

'hardheads'; 'mouss'

Cc: Subject: 'stick' 1995 ISSCC

Well, its that time of year again. The deadline for the "cheaper" registration is Feb 1, so we need to put together a list of who's interested in attending. Same as last year, I volunteer to be the "gatherer" of names, so if you're interested, email me and include your IEEE number if you're a member. I'll complile the the list and see if we can put together a group PO for the registrations.

Please note that both a Short Course and Tutorials are being offered this year, so if you are interested in either or both of these, please indicate in your email.

I have a stack of advanced programs in my office for anyone who's interested and hasn't received one in the mail.

A few highlights.....

# Plenary:

Digital-Storage Media in the Digital-Highway Era Toshiyuki Yamada - Sony (Note - Sony will be giving a demo of their digital VCR)

The Making of the PowerPC Raymond Dupont - IBM

Gigachips: Deliver Affordable Multimedia for Work and Play Via Broadband Netword and the Set-Top Box
Pallab Chatterjee - TI

#### uP's:

133MHz 64b Four-issue CMOS uP {from Motorola - next powerPC}
0.6u BiCMOS Processor {from Intel - P6}
64b uP with Multimedia Support {from Sun}
300MHz Quad-Issue CMOS RISC {from DEC - next Alpha}

## Video Signal Proc.:

An MPEG-1 A/V Decoder with {from C-Cube} Run-Length-Compressed Antialiased Video Overlays

A Helf-Pel Precision MPEG-2 {from Mitsubishi}
Motion-Estimation Processor
with Concurrent Three-Vector
Search

A Single-Chip Videophone Video {from SGS-Thomson} Encoder/Decoder

#### Memories:

An Experimental 220MHz 1Gb DRAM {from Hitachi}

A 1Gb DRAM for File Applications {from NEC}

A 10Mb 3D Frame-Buffer Memory {from Mitsubishi}

z-Compare and alpha-Blend Units

#### Evening Panels:

Silicon Foundries: Partners, Suppliers or Competitors

The Digital Highway: The Off Ramp to the Home

Analog BiCMOS: Luxury or Necessity?

In-House CAD vs. Vendor CAD for High-Perf Processors

Single-Chip Integration vs. Multichip Modules

#### Short Course:

The Role of ATM on the Digital Highway

#### Tutorials:

Intro to Oversampled Data Conversion

Clocking Techniques in uP's

Overview of Radio Comm/RF circuits

Embedded Cache Memory Design

Solid-State Imaging

Sig-Proc in magnetic hard-disk drives.

Anyway, thats the scoop. Don't wait to email me your interest 'cause Feb. 1 is just a couple of weeks away.

BB

mudge (john mudge)

Sent:

Thursday, January 12, 1995 2:25 PM 'cadettes'; 'albers'; 'paulp' 'tomho'; 'michael'; 'geert'; 'tbr'; 'mudge'

To:

Cc:

Subject:

Rules changes

#### Each,

It's my understanding that the recent rules' changes are being implemented in euterpe. am thinking particularly of the collector plug change. We have a number of test patterns in the scribe channel and would like to implement the new rules so that the test patterns reflect what's on the product die. I think that we can probably handle the changes ourselves (Tom, myself and Chris) but how long do we have to do it and are we permitted to do it?

johnnymudge

albers (Daniel Albers)

Sent:

Thursday, January 12, 1995 2:49 PM

To:

'john mudge'

Cc:

'cadettes'; 'paulp (Paul Poenisch)'; 'tomho (Tom Ho)'; 'michael (Chris Michael)'; 'geert (Geert

Rosseel)'; 'tbr (Tim B. Robinson)'; 'mudge (john mudge)'

Subject:

Re: Rules changes

- > the words of john mudge:
- > Each,
- > It's my understanding that the recent rules' changes are being
- > implemented in euterpe. I am thinking particularly of the collector
- > plug change.
- > We have a number of test patterns in the scribe channel and would like
- > to implement the new rules so that the test patterns reflect what's on
- > the product die.
- > I think that we can probably handle the changes ourselves (Tom, myself
- > and Chris) but how long do we have to do it and are we permitted to do
- > it?

Two schedule details to be aware of with regards to editing the cells:

- Frame rebuild takes about 1 day after the etest cells have been released.
  - I have to rebuild the frame because we split the etest cells down

the middle in parameter scribes and there is some synthesis which takes place to generate scribe extenders which protect against mis-step slivers. I would not feel confortable about editing the etest cells and not regenerating the frame.

I will be on vacation 1/18 (next Wed) through 1/27 (1.5 weeks).

So if the schedule permits it, I see no reason not to edit/drc the cells.

Dan

Daniel Albers albers@microunity.com MicroUnity Systems Engineering,

255 Caspian Way, Sunnyvale, CA (408) 734-8100

It can be made into a monster if we all pull together as a team...

paulp (Paul Poenisch)

Sent:

Thursday, January 12, 1995 3:15 PM

To:

'john mudge'

Cc:

'tomho (Tom Ho)'; 'michael (Chris Michael)'; 'geert (Geert Rosseel)'; 'tbr (Tim B. Robinson)';

'cadettes'

Subject:

Re: Rules changes

```
> Each,
> It's my understanding that the recent rules' changes are being
> implemented in euterpe. I am thinking particularly of the collector
> plug change.
> We have a number of test patterns in the scribe channel and would like
> to implement the new rules so that the test patterns reflect what's on
> the product die.
> I think that we can probably handle the changes ourselves (Tom, myself
> and Chris) but how long do we have to do it and are we permitted to do
> it?
> johnnymudge
> johnnymudge
```

#### Johnny,

I agree that the changes should be made. If they are not the scribeline will have to go through a different fracture flow or the collector plugs and well taps will not work at all. Additionally unless you've done something very strange in the test structures the changes should be quite straight forward and quick.

Paul.

tom (Tom Laidig)

Sent:

Thursday, January 12, 1995 4:51 PM

To:

'Paul Poenisch'

Cc:

'mudge@acteon.microunity.com'; 'tomho (Tom Ho)'; 'michael (Chris Michael)'; 'geert (Geert

Rosseel); 'tbr (Tim B. Robinson); 'cadettes'

Subject:

Re: Rules changes

Paul Poenisch writes:

> Each,

> It's my understanding that the recent rules' changes are being

> implemented in euterpe. I am thinking particularly of the collector > plug change.

> We have a number of test patterns in the scribe channel and would > like to implement the new rules so that the test patterns reflect > what's on the product die.

> I think that we can probably handle the changes ourselves (Tom, > myself and Chris) but how long do we have to do it and are we

> permitted to do it?

johnnymudge

> >

I agree that the changes should be made. If they are not the scribeline

will.

have to go through a different fracture flow or the collector plugs and

taps will not work at all. Additionally unless you've done something very

strange in the test structures the changes should be quite straight forward and

quick.

The well tie changes shouldn't be terribly hard to make, I think, since only a few layouts actually contain well ties. Scanning proteus/compass/frame, I find only the following cells that contain geometry on the collector-plug layer:

bicmos fill12x28a1 bicmos fill12x28v2 bpol fill8x28a1 bpol\_fill8x28v2 cmos fill6x12a1

I've been working over the cells in proteus/compass/layouts, and am nearly finished upgrading them to the new rules (I think -- I haven't run any through Dave's new beta DRC flow yet).

Tom L

From: geert (Geert Rosseel)

Sent: Thursday, January 12, 1995 2:45 PM

To: 'tbr

Cc: 'billz'; 'dickson'; 'hopper'; 'mws'; 'wampler'

Subject: Re: Euterpe top level

I believe there i sgoing to be extra space around uu.

Also, and thi sdepends a lot on what hc0 is going to d, but assuming that hc0 is not chagning too much, I believe there might be a gap between nb and at to squeeze a part of lt in.

We have shifted nb to the left with about 60 atoms and Hopper/Billz have done a great job straightening out the edges. I believe that there might be enough room there to put it in. That, of course, will depend a lot on what hc0 wiil do. The last I heard from Jay was that it was growing a lot.

tbr

Sent:

Thursday, January 12, 1995 6:55 PM

To:

'geert (Geert Rosseel)'

Cc:

'billz'; 'dickson'; 'hopper'; 'mws'; 'wampler'

Subject:

Re: Euterpe top level

Follow Up Flag: Follow up

Estlem.

Flag Status:

Red

Geert Rosseel wrote (on Thu Jan 12):

I believe there i sgoing to be extra space around uu.

Also, and thi sdepends a lot on what hc0 is going to d, but assuming that hc0 is not chagning too much, I believe there might be a gap between nb and at to squeeze a part of lt in.

We have shifted nb to the left with about 60 atoms and Hopper/Billz have done a great job straightening out the edges. I believe that there might be enough room there to put it in. That, of course, will depend a lot on what hc0 wiil do. The last I heard from Jay was that it was growing a lot.

It grew more than we were expecting, but woody thinks he can shrink it back a fair bit by reorganizing an overloaded PLA.

Tim

Page 152 of 356

tbr (Tim B. Robinson)

Sent:

Thursday, January 12, 1995 6:55 PM

To:

'geert (Geert Rosseel)'

Cc:

'billz'; 'dickson'; 'hopper'; 'mws'; 'wampler'

Subject:

Re: Euterpe top level

Geert Rosseel wrote (on Thu Jan 12):

I believe there i sgoing to be extra space around uu.

Also, and thi sdepends a lot on what hc0 is going to d, but assuming that hc0 is not chagning too much, I believe there might be a gap between nb and at to squeeze a part of lt in.

We have shifted nb to the left with about 60 atoms and Hopper/Billz have done a great job straightening out the edges. I believe that there might be enough room there to put lt in. That, of course, will depend a lot on what hc0 will do. The last I heard from Jay was that it was growing a lot.

It grew more than we were expecting, but woody thinks he can shrink it back a fair bit by reorganizing an overloaded PLA.

Tim

Tom Eich [tbe@MicroUnity.com] Friday, January 13, 1995 12:45 AM

Sent:

'boxers@MicroUnity.com'; 'dbulfer@MicroUnity.com'

To: Cc:

'pandora@MicroUnity.com'

Subject:

Pandora meeting minutes/actions, 1/12

Actions and status are as follows:

>1) Noel to prepare a power spreadsheet with current by voltage per >module

or

>>lowest separable unit.

Status: in progress.

>2) Noel to determine availability of single and multiple output Cukconverters

>>(syncronous rectifiers) with adequate output for both Euterpe and

>>Mnemo

shricks.

Decision taken to pursue a single integrated multiple output power supply for all modules (with the possible exception of the mixed signal module) as first course. All other dc-dc actions from previous meeting are on hold as a result.

Action: Philip and Noel to prepare power supply trade matrix.

Action: Noel to survey vendors and id candidate supplies.

>snip<

>4) Noel and Vijay to id all signal and signal ground I/O lines for both the

>>Euterpe and Mnemo bricks >snip<

Status: in progress; signal and signal ground requirements identified.

Action: Determine power requirements (ref. 1) above) and candidate power connectors and bus bars.

>5) Noel to identify de-coupling cap requirements and the to include in area

>>calculations and layouts.

Action: in progress.

>6) Noel to investigate with tbr, dbulfer, and geert the implications of >>unsynchronized or disorderly power-up of the various bricks in

>>Pandora,

>>Pandora

Moot with single power supply.

>>specify p/s and system level requirements accordingly.

.7) Howard is trading pluminum as garrow for the m

>7) Herman is trading aluminum vs. copper for the mnemo heatsink. Die attach

>is >assumed to be the same as for the current Euterpe. Issue with aluminum

>wrt low >impedance return path from back of die to pcb.

Action: Herman and the to trade off cost of plating aluminum vs copper and assess other impacts (weight, thermal performance).

>8) Herman to trade-off integral Mnemo fan vs. external system
>blower(s);

tbe

>>and jt to support with layout concepts.

Decision taken to pursue system level blowers for Mnemo modules and PCI cards as a first course, due to noise, size and power impact of individual module fans.

>9) David is preparing a BOM for the clock card; for now he sez to >assume

a

>>single crystal oscillator with 6 ECL parts at 1 Watt each.

The system clock has moved to the PCI/Hermes bridge module.

>10) PCI/Hermes bridge module is not well defined as yet; David is >working on a

>>preliminary BOM; he promises multiple voltage requirements (3.3, 5 and >12 Vdc).

This modules form factor and components/interconnect were discussed. Two approaches were sketched: a) A dual backplane (one for PCI, one for Hermes, orthogonally positioned) with the bridge card having connection to both, and b) a single module between the first PCI card and the Euterpe module with interconnects for PCI, ISA and Hermes to a single system backplane.

Action: jt and the to lay out and iterate to determine optimal configuration.

Discussion of contents of this module yielded following issues:

What system temperature sensing/thermal management is planned relative to each airmover and heat source? Need to determine level of sensing appropriate to disparate modules and heat source. Discussed having system monitoring components on bridge module.

Question: Does Mnemosthene have on chip temperature sensing as do Euterpe and Calliope?

Action: Noel and David to determine location and type of thermal protection in Pandora.

Discussed the PCI card containing the Mnemo and external Hermes port (for hestia, etc). If this card conforms to the PCI mechanical standard, then this Mnemo will need a different heat sink than planned for the modules. Herman said this was possible, but needed to be assessed.

Action: David raised concern relative to 3.3Vdc input if this is standard PCI card that could go in any slot. How to resolve?

Action: Herman to determine feasibility of low profile heat sink and required flow rate.

Next step: make mock ups of modules and chassis for evaluation this for Monday.

Tom Eich
MicroUnity Systems Engineering, Inc.
255 Caspian Dr. Sunnyvale, CA 94089
(408)734-8100, (408)734-8136 fax

tbe@microunity.com

tbr

Sent:

Friday, January 13, 1995 12:55 AM

To:

'Tom Eich'

Cc:

'boxers'; 'dbulfer'; 'pandora'

Subject:

Pandora meeting minutes/actions, 1/12

Follow Up Flag: Follow up

Flag Status:

Red

Tom Eich wrote (on Thu Jan 12):

>6) Noel to investigate with tbr, dbulfer, and geert the implications of

>>unsynchronized or disorderly power-up of the various bricks in Pandora, and

>>specify p/s and system level requirements accordingly.

Moot with single power supply.

This should not be a problem even with multiple supplies. Euterpe comes up executing from boot rom and does not require other Hermes devices to start up. Other devices must be identified, and configured via Cerberus before being accessed via Hermes. If necessary a delay could be introduced to ensure auiliary supplies are available.

>9) David is preparing a BOM for the clock card; for now he sez to assume a >>single crystal oscillator with 6 ECL parts at 1 Watt each.

The system clock has moved to the PCI/Hermes bridge module.

I don't see how that's compatible with the need to have the clock source on the Calliope module when it is present. If we have a defined slot that that module would occupy, which we will have to fill with a herminator if the Calliope module is absent, then I still think putting the clock source there is easiest. Does someone see a problem with that?n

What system temperature sensing/thermal management is planned relative to each airmover and heat source? Need to determine level of sensing appropriate to disparate modules and heat source. Discussed having system monitoring components on bridge module.

Question: Does Mnemosthene have on chip temperature sensing as do Euterpe and Calliope?

Yes, mnemosyne has the same temperature sensor. (We actually need it as part of the bias calibration system.) In addition to the sensor there is also the same overtemperature shutdown circuit.

Tim

tbr (Tim B. Robinson)

Sent:

Friday, January 13, 1995 12:55 AM

To:

'Tom Eich'

Cc:

'boxers'; 'dbulfer'; 'pandora'

Subject:

Pandora meeting minutes/actions, 1/12

Tom Eich wrote (on Thu Jan 12):

>6) Noel to investigate with tbr, dbulfer, and geert the implications of >>unsynchronized or disorderly power-up of the various bricks in Pandora, and >>specify p/s and system level requirements accordingly.

Moot with single power supply.

This should not be a problem even with multiple supplies. Euterpe comes up executing from boot rom and does not require other Hermes devices to start up. Other devices must be identified, and configured via Cerberus before being accessed via Hermes. If necessary a delay could be introduced to ensure auiliary supplies are available.

>9) David is preparing a BOM for the clock card; for now he sez to assume a >>single crystal oscillator with 6 ECL parts at 1 Watt each.

The system clock has moved to the PCI/Hermes bridge module.

I don't see how that's compatible with the need to have the clock source on the Calliope module when it is present. If we have a defined slot that that module would occupy, which we will have to fill with a herminator if the Calliope module is absent, then I still think putting the clock source there is easiest. Does someone see a problem with that?n

What system temperature sensing/thermal management is planned relative to each airmover and heat source? Need to determine level of sensing appropriate to disparate modules and heat source. Discussed having system monitoring components on bridge module.

Question: Does Mnemosthene have on chip temperature sensing as do Euterpe and Calliope?

Yes, mnemosyne has the same temperature sensor. (We actually need it as part of the bias calibration system.) In addition to the sensor there is also the same overtemperature shutdown circuit.

Tim

Sent:

Buffalo Chip [chip@rhea] Friday, January 13, 1995 8:31 AM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/nb BOM 99.0 initiated by hopper completed @ Fri Jan 13
06:26:21 PST 1995 with exit status 0.. chip

Gregg Kellogg [gregg@hts.microunity.com]

Sent: To: Friday, January 13, 1995 12:17 PM 'rnewton@ic.eecs.berkeley.edu'

Subject:

(Fwd) Disk Arrays for Digital Video

--- Forwarded mail from <gregg@hts.microunity.com> ("Gregg Kellogg")

To: newton@eecs.berkeley.edu

Richard,

I thought you would find this interesting as I recall you describing your experiences trying to get your PowerMac to do video well.

Gregg

Date: Thu, 12 Jan 1995 15:48:19 -0500 From: boykin@gte.com (Joseph Boykin)

To: digvid-l@ucdavis.edu

Subject: Experiences building a Disk Array for Digital Video

Message-ID: <ab3b44d60c0210047f97@[132.197.14.175] >

I have been asked by a number of people to summarize my experiences putting together a RAID subsystem for use with digital video. This is a report on those experiences. It is longer than expected, but I have tried to write down a lot of what I have uncovered over the past six months. It also tries to explain some of the matters that must be considered when putting such a system together. For example, \*why\* were the sustained data rates of 3.5MB/s, 5.5MB/s and 6.5MB/s of interest to me? Read on and find out.

First, let me give some background. I do not do digital video professionally, it is purely a hobby, but I'm what you would call a "serious hobbyist". I have been doing video for a number of years, with my primary material source being underwater video (I'm a PADI & SSI instructor and teach courses in U/W video if anyone is interested!) I did my editing on a SONY EVO-9700, but there aren't any whiz-bang features in that deck, e.g. no transitions, and I prefer playing with digital over analog technology anyway.

My end-goal is full-frame, full-motion NTSC video on the order of 5-15 minutes. I'd love S-VHS/Hi8 quality, but I don't want anything less than VHS quality. Even if my final work will be output to VHS quality tape, I want to keep my edits in as high a quality as possible. In other words, I want to be able to hand a tape to someone and have them see it on a TV and not just produce little 160x120 clips for CD-ROMs.

Being a "do it yourselfer" at heart, I put together a system with a Quadra 840AV, Radius VideoVision Studio, and a RAID array. This document talks about my experiences getting that RAID array going and the ancillary things that went along with it..

Looking at the prices for pre-configured arrays, I decided to put one together myself. After all, how hard could it be? To answer that question in advance: I started this in June and I finished in January.

I started with two Micropolis 2236AVs (3GB each). These drives had reasonable capacity, reasonable speed and boasted dealing with Thermal Recalibration (TCal) well. Other than the fact that these drives a) consume a lot of power and b) run pretty hot, they are probably excellent for many applications. However, I ran into a serious problem; they don't stripe well. I put the drives on the same SCSI chain and was surprised to find that I only achieved about a 5% performance increase when striped.

About 25% is more typical for RAID level 0. I eventually learned that these drives do not handle SCSI-2 disconnect/reconnect well (or maybe at all). If the drives were on separate SCSI chains, this wouldn't be a problem. Given that they were on a single chain, the ability to do disconnect/reconnect is required. OK, back to the drawing board.

While Micropolis makes a big deal of their AV drives, in reality, many new drives handle

TCal fairly well. The manufacturers know that the newest large capacity and fast drives are going to be used in digital video, so they are trying to ensure their drives work well for this demanding

environment. They do TCal less often and postpone TCal if a read or write

operation is pended. What that means is that a new non-AV drive may do just fine for you (especially if your disk housing has good cooling).

Drives from both Micropolis and Seagate are the top picks in this category.

Fujitsu and Conner also have mechanisms.that work well, but you need to be sure about a \*particular\* mechanism before you buy it. You can guarantee yourself that any old drives or new drives that aren't at the top of the curve will not handle TCal well. Based on that, I chose four Seagate Barracuda 4's as my disks. The drives are big (4GB each) and fast (7200 RPM, 8ms seek, 1MB cache) and yes, they do postpone TCal. More on the drives later.

Next: the hunt for a SCSI accelerator. There are several out on the market, but based on other people's experience in terms of both performance and reliability I narrowed down my choice to the ATTO and FWB cards. ATTO has a Silicon Express II Fast SCSI-2 card and a Silicon Express IV Fast/Wide card. Street prices are \$725 and \$990 respectively. FWB has their SCSI JackHammer card which supports Fast/Wide transfers at a street price of about \$700. Rumor had it that the ATTO card was a bit faster, so I chose the ATTO SE II (I had bought "narrow" drives). My logic was

simple: with a RAID array and an accelerator, I probably would have enough performance for what I want. You'll see shortly that I was wrong.

The card arrived long before the disks, so I couldn't test things out immediately. By the time I did, the card was about 2 months old and turned out to be flaky (the system would hang when I tried to do any significant amount of I/O to drives attached to the card). I contacted ProDirect, who I purchased the card from, and their Tech support folks told me they didn't even have a system they could test it out on and, since the card was two months old, they wouldn't swap it for a new one anyway. I turned to ATTO, who preferred that I deal with ProDirect, since that is who sold it to me, but after telling them what PD said, they relented. I sent them my card and was pretty quickly told that "It worked for them" and it was returned to me. I was pissed. I tried the card in three systems (2 840s and an

800) again, with the same results. I returned the card to ATTO who still couldn't find anything wrong with it, but agreed to swap it for a new one. The new card arrived and works well (at least, it didn't crash my system).

At this point, I started running a bunch of performance tests. I have three formatting utilities: FWB HDT V1.6, Transoft's SCSI Director Pro V3.07, and CharisMac's Anubis utility V2.52s (I've recently upgraded this to version 2.53 with PowerControl (lets you control mode page settings) and RAID software, but I have not used those features yet. NOTE: I have been told that the CharisMac RAID software is \*not\* very good in its current release). I reformatted one drive with each of these and ran FWB's BenchTest and ATTOs performance utilities to see what I got. A short version of my results: Partition size doesn't matter (except that the FWB benchmark test thinks smaller partitions are faster), under System 7.5 cache size doesn't matter, and the FWB driver did pretty poorly.

Test configuration: Q840AV w/80MB memory; System 7.5. Partition size was 2GB. Using the internal SCSI Bus I achieved:

Driver Sustained Read Sustained Write

 FWB
 2.8MB/s
 3.2MB/s

 CharisMac
 3.0MB/s
 3.6MB/s

 Transoft
 3.0MB/s
 3.6MB/s

As you can see, if you are using the internal SCSI bus the CharisMac and Transoft drivers were about the same with the FWB driver falling significantly behind. I don't know why; perhaps it is the driver itself, perhaps it was some mode page (the disk drive's firmware parameters) settings that the formatter set. My belief is that it is a combination of the two as an e.g. Transoft driver on an FWB formatted drive is faster than an FWB formatted drive with the FWB driver. I never looked into it enough to narrow down the cause any further. (It takes a \*LONG\* time to run these tests and since I didn't have to know why one was faster than another, I just cared which was faster -- there's a point where this being a hobby is an advantage!)

While these are interesting numbers (and caused me to reformat and initialize all the other drives I had access to at home and at work with the Transoft driver!), for eventual use on an accelerator card it didn't matter. When a drive attached to the ATTO card is mounted you use a driver that is in the ATTO firmware. The same is true for the FWB card and any of the current crop of SCSI accelerator cards. The performance data was obtained, and were of interest, because they provide a baseline of comparison.

I moved the drives back to the ATTO card and went to install the RAID software. I have both the ATTO ExpressStripe software and Trillium Research's Remus Limited. I started with the ATTO software (version 2.00) but the system crashed as the INIT was being loaded. ATTO gave me a free upgrade to 2.01 (tech support created an account on their system and let me dial-in via ARA to download the file, very nice of them), but that didn't work either. ATTO then gave me a Beta copy of their 3.0 software and that did work (and is much nicer to use). ATTO Tech support didn't know why 2.0X didn't work, but at that point, I didn't really care.

Reliability of the 3.00 software wasn't very good (what do you want from Beta software?!?) Occasionally, the drives would become inaccessible.
While ATTO was figuring this out, I switched to the Remus software which has an even nicer interface.

Using the Remus software, I tried various configurations. I tried:

striping across two, three and four drives

changing the allocation unit anywhere between 16K per drive to 64K

varied the logical file system size between 256MB and 4GB

varied the size of the system buffer cache.

My peak performance was approximately 5.2MB/s sustained read and 4.5MB/s sustained write. This surprises me. I would have expected writes to be faster (you can do "blind writes" and return control to the application before the actual write completes). The VVS software that "find"s throughput reports about 2.8MB/s from within Premiere V4.0 using QT 2.0.

These results were achieved using a 64K chunk across either 3 or 4 drives (the numbers were close enough the difference doesn't matter), with a 1GB file system. I have heard that striping across three drives is faster than across four, but I didn't see that. Note: The FWB benchmark tests generally show smaller partitions as having better performance. The reason for this (I think) is that their random write tests have to move the disk heads less, thus reducing seek times. Sustained transfer rate, the number of interest in digital video capture, was the same regardless of partition size. I consider the effect of partition size to be an artifact of the benchmark and not a real factor in performance.

I was disappointed with the results as my "dream" was to get about 6.5MB/s through to the application. To do full-frame (640x480) full-motion (60 fields/sec) VHS quality video takes somewhere around 3MB/s if you have a reasonably clean signal. With a "great" signal, this could drop even further. Both my Sony EVO 9700 and camcorder have S-video in/out (S-video has the video signal split into two separate signals "luminance" and "chrominance", plus separate lines for audio), so the signal is pretty good. (RGBS (Separate Red/Blue/Green/Sync) signals would be cleaner, but no consumer, and few "pro-sumer" equipment has them. RF connections (all audio and video signals combined onto one cable-typical for consumer gear) would be the worst and hence require more bandwidth for the same level of quality.

If I want S-VHS quality I'd need about 5.5MB/s. My goal of 6.5MB/s gives me a little extra so that if a random TCal hits, or the drive needs to retry an I/O, I should be able to survive it. I doubt if I will actually capture at 6.5--the difference between 5.5 and 6.5 is generally not visible, even to an experienced eye. Of course, if I'm digitizing images with a lot of detail, and hence do not compress well, that extra throughput would come in handy.

So, my 2.8MB/s was disappointing. I would have been satisfied if I had 3.5MB/s as then I could have done VHS+ quality and been happy enough, but with 2.5 that was not possible, and S-VHS quality was totally out of the question.

Now what? If you missed it, I chose the ATTO Silicon Express II card and Fast SCSI-2 drives. That was the mistake. Thinking that those drives could do 10MB/s I figured that, when striped and with an accelerator card, I wouldn't have too much problem meeting my 3.5MB/s minimums. I was wrong.

I went back to the folks I bought the drives from, Direct Connections, and they agreed to take back the drives and sell me four Fast/Wide Barracuda 4's. They gave me a 100% credit on everything I bought! It wound up costing a "few bucks" to make the switch (wide drives are more expensive), but it wasn't that bad. I had to do a little arm twisting there, but DC was \*superb\* when it came to handling this problem. Without any question, I can endorse people buying from them. (Tell Dave I said Hi).

Now for the accelerator card. I needed to swap the SE II for an SE IV. I went back to ProDirect, told them my sob story, etc. and they basically hung up on me. Even though they sold me a flaky card, they couldn't/wouldn't even attempt to deal with the problem, and most importantly, ATTO was willing to do just about anything to convince them they should do this (e.g. provide new packaging, certify the card was OK, etc) they wanted to have nothing to do with me. From a pure business standpoint I can't really blame them. After all, the card was five months old at this point (even though I only had a working system for about two weeks), from a customer satisfaction stand point, and from the standpoint of having nothing to lose (ATTO was willing to stand behind the "used"

card), and I was going to buy the more expensive SE-IV, they didn't even want to consider it. More than the fact that they wouldn't help, it was their attitude that was bad, and for that reason, I have no intentions of going back to ProDirect again.

When Direct Connections shipped the four fast/wide Barracuda 4's, I also bought a Silicon Express IV card from them. That leaves me with a Silicon Express II to sell, so if anyone wants it, I currently have an SE-II that I'm looking to sell. A good card, just not what I needed.

Anyway, I put the system together and began running some tests. Performance was \*significantly\* better (I should hope so!). Using Remus Limited RAID level 0 software and FWB BenchTest to measure performance, I achieve the following:

| Configuration   | Sustained Read (MB/s) | Sustained Write | (MB/s) |
|-----------------|-----------------------|-----------------|--------|
| Single drive:   | 5.4                   | 9.3             |        |
| Two drives:     | 8.4                   | 13.3            |        |
| Three drives:   | 8.9                   | 13.3            |        |
| Four drives:    | 9.4                   | 13.2            |        |
| FWB (2 drives): | 8.2                   | 9.2             |        |
|                 |                       |                 |        |

All tests were done on a Q840AV running System 7.5, numerous INITs (I fill the bottom of the screen on startup), and four fast/wide Barracuda 4s (ST15150W). I chose to benchmarks with all INITs enabled as that would be my execution environment, rather than a minimal system (although I turn AppleTalk off, don't use a screensaver, etc). I prefer "real world"

scenarios. However, I ran a subset of the benchmarks with most INITs disabled (I still needed QuickTime, VVS, Remus and the like) and found that there was no significant difference in performance results (it was slightly faster without the INITs, but not by enough to mean anything). This surprised me, but I'm not complaining. I haven't tested the performance with and without INITs with the VVS "find" command, but I would expect that there would be a slight hit.

Except for the last test, all drives were connected to an ATTO SiliconExpress IV card with V9 PAL and Version 1.4 firmware. The partitions were all 2GB logical partition and were the first partition on the disk (additional partitions are generally slower). The final number was using an FWB SCSI JackHammer card and FWBs RAID Toolkit software. Remus is supposed to work with the FWB card, but I could not get it to do so. As the FWB card was borrowed from a friend, I did not have the time to diagnose the problem. This test was done using two drives (the most the FWB software supports). Note: One strange problem was found with the FWB

card: when that card was installed, my system would not boot from my standard startup disk. Instead, it always went to a backup system folder I keep on a different drive. Once the system was up I could manually mount the other partition. Strange.

Why is read performance so much less than write? I believe the answer has to do with both the ATTO hardware and Remus software, although I haven't looked into it enough to find out. My guess is that, between the two, they are simply buffering write requests and immediately returning control to the application prior to the write taking place, never mind actually completing. The result Is high (and fairly constant) write throughput).

The configuration I am using has four 4GB partitions striped across four drives. Using four drives has several advantages and disadvantages.

Additional drives help read performance. As each drive has a 1MB cache, if I only access one partition at a time, I effectively quadruple my on-board disk cache. How much that is also helping read performance I cannot estimate, but the end result is the same. In addition, the large per-drive cache also helps in dealing with TCal--the drive controller can buffer data while the mechanism is unavailable during TCal. The downside is that with more drives there is a higher probability of failure. In addition, if I lose one drive I lose 16GB of data. For many, that could be enough reason to stay away from this configuration! On the other hand, for myself, I am not concerned about the loss. First, as I've said before, this is a hobby; the world will not end for me if I get set back a little. Second, I have two 8mm Exabyte tape drives on my system and do automated nightly backups with Retrospect. Even with a catastrophic failure, I won't lose much.

a big believer in backups!

The Radius VideoVision Studio "find" command reports about 5.8MB/s (5.9 without audio) through to Premiere. Slightly less than my optimal 6.5, but more than the 5.5 I really needed for S-VHS quality. At this point, I'm happy and am capturing and editing full-motion, full-frame video and the fish are gorgeous!

Effect of partition size: as in the past, I see a significant difference in FWB's overall index of performance based on partition size. The larger the partition, the worse the rated performance. Again, I consider this to be an artifact of the benchmark test, not a true measure. Regardless, for digital video my interest is in sustained transfer rate. Even if the performance is worse with larger partitions, my measurements show no difference in sustained transfer rate as a function of partition size.

Effect of buffer cache: I am currently using System 7.5. Apple made some significant changes to their disk buffer cache algorithms in this release. Previously, a larger buffer cache would not help performance and, especially for digital video, could hurt performance. I ran the same tests using buffer cache sizes of 32KB, 192KB, 1MB and 2MB and found no significant difference between them.

I've seen 17MB/s in ads, why aren't these numbers even close?: Several RAID vendors advertise about 17MB/s in their ads. They do so by using \*two\* SCSI accelerator cards. For most systems, using two SCSI channels doesn't buy you much. I've traded benchmark numbers with several people using Seagate Barracuda drives on 8100/80's (which has two SCSI

busses) and their performance is about the same as mine using a single bus. However, when using an 840AV (which has a very fast NuBus), dual SCSI channels can help-in fact, if the numbers are accurate, it looks like it helps to the tune of about 30% (and about \$1,000!).

That's the good news. The bad news is that these are not real-world benchmark numbers. My bet is that the NuBus and CPU are saturated at that point and not much else is going to go on. Given that the goal of all that throughput is to capture and play back video, when another NuBus card like the VVS is also sitting on the bus, your actual throughput may go \*down\*

This is because there is too much bus contention, and limited bus perormance. I recently had the opportunity to demonstrate this to an acquintance who had such a setup--to say the least, he was surprised that his very expensive RAID array was hurting rather than helping him! He pulled the second NuBus card and we started capturing video with fewer dropped frames and more throughput. This may be counter-intuitive until you realize that you these cards are using "more than their fair share" of a very limited resource. Note that using multiple SCSI accelerators will work a lot better when we have faster busses (e.g. PCI) and faster CPUs.

Acknowledgements and comments about vendors: ATTO: ATTO was pretty amazing. I think those guys are triple jointed because they bent over backwards for me in more ways than I could count. They were there at every step of the way, doing everything possible to both make my system work and, more importantly, their attitude was right. When my SE-IV had some funny symptoms, they volunteered to have me just ship the entire system, on their nickel, to them and they would take a look at it from there. The comment from ATTO was "you've been at this too long with too many problems, let's fix it." These guys, and in particular, Mike Woltz in tech support, are champs.

Radius: Mike Jennings of Radius's digital video team, and one of the people who has been pulling \*his\* hair out over at Radius to make disk arrays work well in the digital video world and I have had numerous email exchanges on this topic. While I may be the owner of a VVS, his advice and comments on my efforts have gone well beyond what one would expect from an engineer at such a company. His comments on this document (he proofread several pre-releases) have also been invaluable. Indeed, the notes on throughput requirements for various video quality and signal conditions are mostly his.

Direct Connections: As I said previously, these folks have been very cooperative and willing to help. I haven't received, and didn't ]the type of technical support I received from ATTO and Radius, but they have been great to work with. If you need peripherals, I heartily recommend them.

ProDirect: A good place to avoid. I'm sure many will reply saying how they had great experiences with ProDirect--that is always true, some people have good and some have bad experiences with vendors. My experiences were uniformly bad. When ATTO tried to help, they didn't return ATTOs phone calls. It seems to me this is a place to avoid.

Final note: What is described in this document is based on my own experiences. While I have received help from many corners, I have not stated anything that I have not directy experimented with and discovered myself. The errors are therefore exclusively my own. As I have done this work on my own time, with my own (or borrowed) hardware and software, this document does not represent opinions of, and is not endorsed by, my employer. I do not guarantee that you will have the same, or even similar results.

This has been an interesting exercise. I hope to expand upon it if and when additional hardware and software become available to me. If so, I will announce the results and, eventually, make this information available electronically.

Joseph Boykin
Principal Investigator
Distributed Computing Systems
GTE Laboratories, Inc.

First Vice-President
IEEE Computer Society

Email: j.boykin@computer.org

--- End of forwarded mail from <gregg@hts.microunity.com> ("Gregg Kellogg")

Gregg Kellogg MicroUnity Systems Engineering, Inc. 255 Caspian Drive, Sunnyvale, Ca 94089-1015 gregg@microunity.com

hopper (Mark Hofmann)

Sent:

Friday, January 13, 1995 1:18 PM

To:

'Bill Zuravleff'

Cc:

'tbr (Tim B. Robinson)'

Subject: Re: planet crashed

#### Bill Zuravleff writes:

hopper,

Planet crashed on me while compiling euterpe pla's. I don't know if this is planet's fault or if I just wasn't sticking my tongue out correctly. Anyway, you said let you know. I'm going to try again.

A log file is:

/u/billz/euterpe/verilog/bsrc/dcacheeasy V.simlog.planet.crashed

Regards, billz

Bill,

I'd like to have a look but I'me having a little trouble. Where is the input file? Where is the core file? From where did you run make?

-thanks, hopper From: hopper (Mark Hofmann)

Sent: Friday, January 13, 1995 1:20 PM

To: 'Tim B. Robinson'

Cc: 'woody (Jay Tomlinson)'

Subject: Re: New version of Planet released

#### Tim B. Robinson writes:

Mark Hofmann wrote (on Fri Jan 13):

When used with the new t2pla splitting capability (also just installed) large PLAs can be broken down into smaller pieces, individually optimized by Espresso, and then re-combined for an substabtial gate savings. On a single example in Mnemo Alan saw ca. 35% reduction in atom count.

That's great! Do we have any candidates in Euterpe?

I believe Jay has a PLA that might be susceptible to this technique.

-hopper

From: hopper (Mark Hofmann)

Sent: Friday, January 13, 1995 1:46 PM

To: 'billz (Bill Zuravleff)'

Cc: 'tbr (Tim B. Robinson)'; 'tom (Thomas Laidig)'

Subject: planet dump

#### Hi Bill,

Well I'm stumped on this one. The core file is indeed from Planet. However, I can run that checked-in version of that PLA just fine.

Here's what gdb has to say:

```
gdb-4.11 planet.ex /n/ghidra//s2/euterpe/verilog/bsrc/uu/core
Core was generated by 'planet.ex'.
Program terminated with signal 11, Segmentation fault.
#0 0x265d8 in bufsync ()
(gdb) where
#0 0x265d8 in bufsync ()
#1 0xf19a2008 in end ()
#2 0x26b8c in free ()
#3 0x26034 in fclose ()
#4 0x46f0 in main (argc=0, argv=0xefff5bb4) at planet.c:388
(gdb) print vlogfl
1 = (\text{struct iobuf *}) 0x42430
(gdb) print *vlogfl
$2 = { cnt = 8192, }
rff3_1 UrsrvdSel_0 (phi_A, phi_B, rsrvdSel_N_0_0, rsrvdSel_N_2_1,"...,
base = 0x5ad18 "vdSel_1_2, rsrvdSel_N_1_2;\nor2_1 UrsrvdSel_1_2 (inst_N[31],
inst_N[30], rsrvdSel_1_2, rsrvdSel_N_1_2);\n\n/\"OR\" plane from planet...\n\n
orff3_1 UrsrvdSel_0 (phi_A, phi_B, rsrvdSel_N_0_0, rsrvdSel_N_2_1,"...,
 bufsiz = 8192, flag = 10, file = 4 \ \004
```

It looks like fclose is seg faulting.

Bill- did you try this more than once? Is it repeatable for you?

Tom- could the named stream have gone away due to a network funny and caused this error? Any ideas?

-thanks, hopper From: mws (Mark Semmelmeyer)
Sent: Friday, January 13, 1995 3:25 PM

To: 'hopper (Mark Hofmann)'

Cc: 'tbr (Tim B. Robinson)'; 'woody (Jay Tomlinson)'; 'dickson (Richard Dickson)'; 'billz (Bill

Zuravleff)'; 'lisar (Lisa Robinson)'; 'geert (Geert Rosseel)'

Subject: planet core dumps on iofs

I have had some trouble with the new planet. I found that it helps if everything is run through PLAT to get the number of #'s right as planet expects (the default rule does this, but I had some driver stuff in yy that needed custom treatment that wasn't using PLAT). I also had some trouble in GT with the gtspearly thing but I think that was because I hit ^C at a bad time? So watch out.

But now it wants to rebuild iofs.v from iofs. Veqn and core dumps:

```
/u/chip/tools/bin/planet.ex: opening Espresso-format input file `iofs.optesp'
/u/chip/tools/bin/planet.ex: creating Verilog output file `iofs.v'
/u/chip/tools/bin/planet.ex: creating Pim output file `iofs.pim'
/u/chip/tools/bin/planet.ex: parsing PLA file and building datastructures... /u/chip/tools/bin/planet.ex: ## Input phase is not specified.
/u/chip/tools/bin/planet.ex: PLA has 31 inputs 14 outputs 34 pterms
/u/chip/tools/bin/planet.ex: Phase 111111111111111
/u/chip/tools/bin/planet.ex: Making netlist...
/u/chip/tools/bin/planet.ex: Writing Verilog file `iofs.v'...
/u/chip/tools/bin/planet.ex: Writing Pim file `iofs.pim'...
/u/chip/tools/bin/planet.ex: 1 output OR rank required
/u/chip/tools/bin/planet.ex: Maximum primary input fanout: 20 [rst]
/u/chip/tools/bin/planet.ex: Maximum input plane fanin: 6 [pterm 1]
                                This pterm drives a maximum output plane
/u/chip/tools/bin/planet.ex:
fanin of: 9 [out<1>]
/u/chip/tools/bin/planet.ex: Maximum input plane fanout: 1 [pterm 1]
/u/chip/tools/bin/planet.ex: Maximum output plane fanin: 9 [out<1>] #
/u/chip/tools/bin/planet.ex Version 0.1.19 Fri Jan 13 17:00:07 PST 1995 #
/u/chip/tools/bin/planet.ex -clock -diffin -diffout -flipflop -pimWidth 200 -verilog
```

#### The .optesp file is:

```
#/n/auspex/s24/mws/euterpe/tools/bin/plat Version 0.1.9 Tue Dec 13 17:02:20 PST 1994 ##
/n/auspex/s24/mws/euterpe/tools/bin/espresso.mu -s -s -s iofs.esp ## UC Berkeley, Espresso
Version #2.3, Release date 01/31/88
```

##/\* \$Id: iofs.Veqn,v 3.1 1994/07/15 10:47:17 LT tbr Exp \$ \*/ ## PLA is iofs.esp with 31 inputs and 14 outputs ## ON-set cost is c=34(34) in=98 out=34 tot=132 ## OFF-set cost is c=37(37) in=98 out=38 tot=136 ## DC-set cost is c=0(0) in=0 out=0 tot=0 ## Input phase is not specified.

## ESPRESSO Time was 0.08 sec, cost is c=34(0) in=98 out=34 tot=132 #.i 31

# 0 14

#.0 14

#.ilb rst pre[13] pre[12] pre[11] pre[10] pre[9] pre[8] pre[7] pre[6] pre[5] pre[4] pre[3]
pre[2] pre[1] m[3] m[2] m[1] m[0] state[13] state[12] state[11] state[10] state[9]
state[8] state[7] state[6] state[5] state[4] state[3] state[2] state[1] #.ob out[13]
out[12] out[11] out[10] out[9] out[8] out[7] out[6] out[5] out[4] out[3] out[2] out[1]

frame #.p 34
#0------0110-----1---- 00000000000010
#0------1000---1---- 00000000000010
#0------1010--1----- 00000000000010
#0------1011-1----- 00000000000010
#0------1011-1----- 00000000000010
#0------1100-1----- 00000000000010

```
#1--1------ 0010000000000
#1---1----- 00010000000000
#1---- 00001000000000
#1---- 0000010000000
#1----- 00000010000000
#1----- 0000001000000
#1---- 0000000100000
#1----- 0000000010000
#1----- 000000000001000
#0----- 0000001000000
#0----- 0000000100000
#0----- 0000000010000
#0----1- 00000000001000
#0----1 0000000000100
#0---- 1000000000000
#0----- 0100000000000
#0----- 0010000000000
#0----- 0001000000000
#0----- 0000100000000
#0----- 0000010000000
#0----- 0000010000000
#----- 000000000000 #.e
.i 31
.0 14
.p 34
inputnames rst pre[13] pre[12] pre[11] pre[10] pre[9] pre[8] pre[7] pre[6] inputnames.
pre[5] pre[4] pre[3] pre[2] pre[1] m[3] m[2] m[1] m[0] state[13] .inputnames state[12]
state[11] state[10] state[9] state[8] state[7] state[6] .inputnames state[5] state[4]
state[3] state[2] state[1] .outputnames out[13] out[12] out[11] out[10] out[9] out[8]
out[7] out[6] out[5] .outputnames out[4] out[3] out[2] out[1] frame #.phase
111111111111111
11----- 10000000000000
1-1---- 01000000000000
1--1----- 00100000000000
1---1----- 0001000000000
1---1----- 0000100000000
1---- 0000010000000
1----- 0000010000000
1----- 0000001000000
1----- 0000000100000
1----- 0000000010000
1----- 00000000001000
0----- 0000001000000
0----- 0000000100000
0----1-- 0000000010000
0----1- 0000000001000
0-----1 0000000000100
0----- 1000000000000
0----- 0100000000000
0----- 0010000000000
0----- 0001000000000
0----- 0000100000000
0----- 00000100000000
0----- 000001000000
```

----- 00000000000001 .e

tbr

Sent:

Friday, January 13, 1995 4:00 PM

To:

'lisar'

Subject:

forwarded message from Don Rozenberg

Follow Up Flag: Follow up

Flag Status:

Red

----- Start of forwarded message -----

Return-Path: <rozen>

Received: from rhodan, microunity.com by gaea.microunity.com (4.1/muse1.3)

id AA25555; Fri, 13 Jan 95 12:30:45 PST

Received: from localhost by rhodan.microunity.com (8.6.4/muse-sw.3)

id MAA08449; Fri, 13 Jan 1995 12:30:44 -0800

Message-Id: <199501132030.MAA08449@rhodan.microunity.com>

X-Mailer: ELM [version 2.3 PL11] From: rozen (Don Rozenberg)

To: tbr (Tim Robinson)

Cc: iimura (Wally Iimura), guarino (Loretta Guarino)

Subject: Unix test follow up Date: Fri, 13 Jan 95 12:30:44 GMT

Tim,

Wally has gotten his test case of UNIX code to work on "terp --c". This code utilizes kernel code to handle GTLB misses and Protection Exceptions. Those exceptions are thought to be the principal features exercised by the UNIX kernel but not the STB code. The estimated running time on the icos box is about 1.5 hrs. We could probably reduce that estimate by simplifying the initialization code (scaffolding) which is also taken from the UNIX kernel and which accounts for about two thirds of the time. In addition, the test generates a number (250) random tests and if desired that could also be condensed.

Don Rozenberg
MicroUnity Systems Engineering, Inc.
255 Caspian Drive, Sunnyvale, CA 94089
(408) 734-8100 FAX (408) 734-8136
------ End of forwarded message ------

Page 170 of 356

noel (Noel Verbiest)

Sent:

Friday, January 13, 1995 6:56 PM

To:

'pandora'; 'boxers'

Cc:

'noel'

Subject:

Pandora Power Requirements

Herewith a first tabulation of the power supply requirements for Pandora. Please note that these are educated estimations. The real values will depend on which ISA and PCI cards will be used, how Euterpe and Caliope will come in, etc..

#### VOLTAGE/CURRENT REQUIREMENTS :

| Function     | 3.3V  | 5V    | -5v  | 12v  | -12v | Fan  | Other  |      |
|--------------|-------|-------|------|------|------|------|--------|------|
| Euterpe Bri  | ck    | 28A   | 0    | 0    | 0    | 0    | ?      | ?    |
| Mnemo 1      | 15.5A | 0     | 0    | 0    | 0    | ?    | ?      |      |
| Mnemo 2      | 15.5A | 0     | 0    | 0    | 0    | ?    | ?      |      |
| Mnemo 3      | 15.5A | 0     | 0    | 0    | 0    | ?    | ?      |      |
| Mnemo 4      | 15.5A | 0     | 0    | 0    | 0    | ?    | ?      |      |
| PCI/H Bridge | е     | 10A   | 3A   | 0    | 0.5A | 0.1A | ?      | ?    |
| Caliope 1    | 20A   | 1A    | 0.5A | 1A   | 0.5A | ?    | 48V/0. | . 2A |
| Caliope 2    | 20A   | 1A    | 0.5A | 1A   | 0.5A | ?    | 48V/0  | . 2A |
| ISA 1 Multi  | IO    | 0     | 5A   | 0.5A | 0.5A | 0.1A | ?      | ?    |
| ISA 2        | 0     | 5A    | 0.5A | 0.5A | 0.1A | ?    | ?      |      |
| ISA 3        | 0     | 5A    | 0.5A | 0.5A | 0.1A | ?    | ?      |      |
| PCI 1 SCSI   | 0     | 5A    | 0    | 0.5A | 0.1A | ?    | ?      |      |
| PCI 2 SVGA   | 0     | 5A    | 0    | 0.5A | 0.1A | ?    | ?      |      |
| PCI 3 E-net  | 0     | 5A    | 0    | 0.5A | 0.1A | ?    | ?      |      |
| PCI 4 Spare  | A8    | 5A    | 0    | 0.5A | 0.1A | ?    | ?      |      |
| Prot./Sign.  | 0     | 0.5   | 0.5  | 0.1  | 0.1  | ?    | ?      |      |
| TOTAL        | 86A   | 40.5A | 3.0A | 6.1A | 1.9A | ?    | 48V/0. | 4A   |

#### POWER REQUIREMENTS :

| Function<br>Total    | 3.3V  | 5V    | -5V  | 12V  | -12V | Fan  | Other | Н |
|----------------------|-------|-------|------|------|------|------|-------|---|
| Euterpe Bri          | ck    | 92.4W | 0    | 0    | 0    | 0    | ?     | ? |
| Mnemo 1<br>51.2W     | 51.2W | 0     | 0    | 0    | 0    | ?    | ?     |   |
| Mnemo 2<br>51,2W     | 51.2W | 0     | 0    | 0    | 0    | ?    | ?     |   |
| Mnemo 3<br>51.2W     | 51.2W | 0     | 0    | 0    | 0    | ?    | ?     |   |
| Mnemo 4<br>51.2W     | 51.2W | 0     | 0    | 0    | 0    | ?    | 3     |   |
| PCI/H Bridge         | е     | 33.3W | 15W  | 0    | 6W   | 1.2W | ?     | ? |
| Caliope 1            | 66.6W | 5W    | 2.5W | 12W  | 6W   | ?    | 10W   |   |
| Caliope 2<br>102.1W  | 66.6W | 5W    | 2.5W | 12W  | 6W   | ?    | 10W   |   |
| ISA 1 Multi<br>34.7W | IO    | 0     | 25W  | 2.5W | 6W   | 1.2W | ?     | ? |

| ISA 2<br>34.7W       | 0     | 25W  | 2.5W | бW   | 1.2W | ?    | ? |   |
|----------------------|-------|------|------|------|------|------|---|---|
| ISA 3<br>34.7W       |       | 0    | 25W  | 2.5W | 6W   | 1.2W | 3 | ? |
| PCI 1 SCSI<br>32.2W  | 0     | 25W  | 0    | 6W   | 1.2W | ?    | ? |   |
| PCI 2 SVGA<br>32.2W  | 0     | 25W  | 0    | 6W   | 1.2W | ?    | ? |   |
| PCI 3 E-net          | 0     | 25W  | 0    | 6W   | 1.2W | ?    | ? |   |
| PCI 4 Spare<br>58.6W | 26.4W | 25W  | 0    | 6W   | 1.2W | ?    | ? |   |
| Prot./Sign.<br>7.4W  | 0     | 2.5W | 2.5W | 1.2W | 1.2W | ?    | ? |   |

V Total 490.1W 202.5W 15W 73.2W 22.8W ? 10W 823.6W

If the Power Supply + Cooling is 72.5% efficient, then the Power drawn from a

120 V AC outlet amounts to : 1136 Watts.

Adding a decent quality 21" monitor to the same outlet will require another

200 Watts from that outlet.

Which brings the system total to 1336 Watts.

A typical outlet allows for 120 V x 12 A = 1440 Watts.

The question marks in the "fan" column are there because it is not yet known with

certainty whether we will have distributed cooling for each brick (requiring a

dedicated "fan power buss") or centralized cooling (or a combination of both).

Herman is sweating the cooling this very moment.

The "Other" column refers to the distribution of unusual power (e.g.: 48 Volt DC

for special VCO's) or "raw DC" (used to make "super clean" secondary voltages

for audio or RF functions).

The "Prot./Sign." row refers to Protection and Signaling circuitry. It is the

intend to measure temperature and other vital information at critical points in

the box and display/shut it down if need be.

Comments and feedback invited. I'll be the keeper of the spreadsheets.

Noel x787

dbulfer (David Bulfer)

Sent:

Friday, January 13, 1995 8:04 PM

To:

'Noel Verbiest'

Cc:

'pandora'; 'boxers'; 'noel (Noel Verbiest)'

Subject:

Re: Pandora Power Requirements

This is a little overstated. The PCI slots have an maximum of 25W, not the combined total of all supply currents. That is only useful in sizing the power supply.

More realistic would be:

#### POWER REQUIREMENTS :

```
Euterpe Brick
                   92 W
            51 W
Mnemo 1
             51 W
Mnemo 2
Mnemo 3
             51 W
Mnemo 4
             51 W
PCI/H Bridge
                   55 W
Caliope 1
            102 W
            102 W
Caliope 2
ISA 1 Multi IO
                   25 W (Typical of 10W)
ISA 2
             25 W (Typical of 10W)
ISA 3
                   25 W (Typical of 10W)
PCI 1 SCSI
             25 W (Typical of 10W)
PCI 2 SVGA
             25 W (Typical of 10W)
PCI 3 E-net 25 W (Typical of 10W)
PCI 4 Spare 25 W (Typical of 10W)
Prot./Sign.
              7 W
```

### Add:

- \* 1.2GB SCSI Disk .75A @ 5V .6A @ 12V -----
- \* 20" Color Monitor @ 330W

737 W

For a total of 1078 W

How much is available:

- \* In a standard office environment, UL permits 80% of the circuit maximum 15A @ 110V => 12A
- \* Assume you have a low AC line of 100 VAC (I suspect we spec 100 120VAC).
- \* Assume 99% Power Factor Correction
- \* Assume that the power supply is 75% efficient.

You have 891 W of available power (12 A \* 100V \* 99% \* 75%).

===> This means we are short 187 W! <===

David

```
Sent:
                     Friday, January 13, 1995 8:12 PM
To:
                      'David Bulfer'
                      'noel@MicroUnity.com'; 'pandora@MicroUnity.com'
Cc:
                     Re: Pandora Power Requirements
Subject:
>This is a little overstated. The PCI slots have an maximum of 25W, not
>the combined total of all supply currents. That is only useful in
>sizing the power supply.
>More realistic would be:
>POWER REQUIREMENTS :
                  92 W
>Euterpe Brick
>Mnemo 1
                  51 W
>Mnemo 2
                  51 W
                  51 W
>Mnemo 3
>Mnemo 4
                  51 W
>PCI/H Bridge
                  55 W
>Caliope 1
                 102 W
                 102 W
>Caliope 2
>ISA 1 Multi IO
                  25 W (Typical of 10W)
>ISA 2
                  25 W (Typical of 10W)
>ISA 3
                  25 W (Typical of 10W)
>PCI 1 SCSI
                  25 W (Typical of 10W)
>PCI 2 SVGA
                  25 W (Typical of 10W)
                  25 W (Typical of 10W)
>PCI 3 E-net
>PCI 4 Spare
                  25 W (Typical of 10W)
>Prot./Sign.
                   7 W
                 737 W
>
Don't forget fans: 1 for Euterpe, say 2 for the four Mnemos, 1 for the PCI area all at
12V@ .8A steady state for a total of 38.4 W load.
>Add:
   * 1.2GB SCSI Disk
       .75A @ 5V
       .6A @ 12V
       _____
       11 W
   * 20" Color Monitor @ 330W
>For a total of 1078 W
>How much is available:
   * In a standard office environment, UL permits 80% of the circuit
       maximum 15A @ 110V => 12A
   * Assume you have a low AC line of 100 VAC (I suspect we spec 100 -
       120VAC).
   * Assume 99% Power Factor Correction
   * Assume that the power supply is 75% efficient.
>You have 891 W of available power (12 A * 100V * 99% * 75%).
>===> This means we are short 187 W! <===
```

Tom Eich [tbe@MicroUnity.com]

From:

> >David

Even more if the fans are included; btw, what comprises the 102 W number for Calliope module load?

Regards,

-Tom

Tom Eich MicroUnity Systems Engineering, Inc. 255 Caspian Dr. Sunnyvale, CA 94089 (408)734-8100, (408)734-8136 fax tbe@microunity.com

dbulfer (David Bulfer) From: Friday, January 13, 1995 8:16 PM Sent: 'David Bulfer' To: 'noel@MicroUnity.com'; 'pandora'; 'boxers'; 'noel (Noel Verbiest)' Cc: Re: Pandora Power Requirements <=== Correction Subject: Sorry, I double counted the monitor power supply efficiency. This is a little overstated. The PCI slots have an maximum of 25W, not the combined total of all supply currents. That is only useful in sizing the power supply. More realistic would be: POWER REQUIREMENTS : Euterpe Brick 92 W Mnemo 1 51 W Mnemo 2 51 W 51 W Mnemo 3 Mnemo 4 51 W 55 W PCI/H Bridge 102 W Caliope 1 Caliope 2 102 W ISA 1 Multi IO 25 W (Typical of 10W) 25 W (Typical of 10W) ISA 2 ISA 3 25 W (Typical of 10W) PCI 1 SCSI 25 W (Typical of 10W) PCI 2 SVGA 25 W (Typical of 10W) PCI 3 E-net 25 W (Typical of 10W) PCI 4 Spare 25 W (Typical of 10W) 7 W Prot./Sign. 737 W Add:

\* 1.2GB SCSI Disk .75A @ 5V .6A @ 12V 11 W

\*\*\*\*\*\* Corrected calculations below \*\*\*\*\*\*\*

Total DC power = 748 W

- \* Assume 99% Power Factor Correction
- \* Assume that the power supply is 75% efficient.

DC Power Supply Power is 748 W / (99% \* 75%) = 1007 W

Now add:

\* 20" Color Monitor @ 330W (my xterm's monitor spec)

For a Total AC power of 1337 W.

How much is available:

- \* In a standard office environment, UL permits 80% of the circuit maximum 15A @ 110V => 12A
- \* Assume you have a low AC line of 100 VAC (I suspect we spec 100 120VAC).
- \* Therefore the available power is 1200 W

===> This means we are short 137 W <===

David

> > > > -

David Bulfer

email: dBulfer@MicroUnity.Com

Phone: 408-734-8590 x282

FAX: 408-734-8136

SnailMail: MicroUnity Systems

Engineering, Inc. 255 Caspian Drive

Sunnyvale CA 94089-1015

tbr

Sent:

Friday, January 13, 1995 8:48 PM

To:

'hopper (Mark Hofmann)'

Cc:

'hardheads'; 'karzes'

Subject:

New version of Planet released

Follow Up Flag: Follow up

Flag Status:

Red

#### Mark Hofmann wrote (on Fri Jan 13):

This version supports the new "-merge outFile" option. You can now invoke Planet like so:

planet [other options] -merge merged pla1.esp pla2.esp pla3.esp ...

Planet will read the separate .esp files and combine them into a single PLA which can then be written out as a monolithic .v file (called "merged.v" in this example). Note that signals in the module name will begin with those given in pla1 followed by pla2, etc.

When used with the new t2pla splitting capability (also just installed) large PLAs can be broken down into smaller pieces, individually optimized by Espresso, and then re-combined for an substabtial gate savings. On a single example in Mnemo Alan saw ca. 35% reduction in atom count.

That's great! Do we have any candidates in Euterpe?

Tim

Exhibit C10

tom (Tom Laidig)

Sent:

Friday, January 13, 1995 9:27 PM

To:

'hardheads'

Cc:

'tom (Thomas Laidig)'

Subject:

atlas and cronus areas created

I've created the toplevel directories for two new chip design areas:

#### atlas

This is the cmos equivalent of proteus, so named because it will support the world (well, the world of cmos, anyway -- hey, names with any mnemonic significance are getting scarce). I've installed a bare bones version of ged, which undoubtedly needs improvement, but should be enough to let people start drawing schematics.

#### cronus

This is the cmos version of euterpe, named because we really have to get this done on time. Only the top-level directory exists as of now.

Enjoy.

tbr

Sent:

Saturday, January 14, 1995 4:24 PM

To:

'Lisa Robinson'

Subject:

regression/1887: c\_euterpe\_wrap BOM: 201.0 regression run - ./14195.12167

Follow Up Flag: Follow up

Flag Status:

Red

# Lisa Robinson wrote (on Sat Jan 14):

>Number:

1887

>Category:

regression

>Synopsis:

c\_euterpe\_wrap BOM: 201.0 regression run - ./14195.12167

Please take me off the list !!!

Tim

hopper (Mark Hofmann)

Sent:

Monday, January 16, 1995 4:30 AM

To:

'Tim B. Robinson'

Cc:

'agc (Alan Corry)'; 'lisar (Lisa Robinson)'; 'billz (Bill Zuravleff)'; 'dickson (Richard Dickson)';

'geert (Geert Rosseel)'; 'mws (Mark Semmelmeyer)'; 'woody (Jay Tomlinson)'

Subject:

Re: Coprolite polishing

# Tim B. Robinson writes:

I think we ought to think seriously about freezing the version we are using on euterpe. Even in the absense of new problems like the unexpected instance name changes, we are losing a lot of time with constantly having to regenerate things.

The latest code will definitely improve some of the PLAs Alan has been looking at for Mnemo. So far we don't have an example of a similar improvement with Euterpe. So perhaps we freeze the Euterpe version to what we are currently running.

-hopper

paulp (Paul Poenisch)

Sent:

Monday, January 16, 1995 10:52 AM

To: Cc: 'Tom Laidig' 'hardheads'

Subject:

Re: atlas and cronus areas created

```
> I've created the toplevel directories for two new chip design areas:
> atlas
> cronus
> Enjoy.
> --
> 00000 00000
> ( _) (_ )
> \( tau )/
> (_) (_)
```

I agree with solo, this is going to get confusing if different chips, projects and machines are sharing the same name. I would recommend the name tisiphone, which has phonetic similarities to both terpsichore and euterpe and may have mythological significants on several levels.

Paul.

tbr (Tim B. Robinson)

Sent:

Monday, January 16, 1995 12:28 PM

To:

'hopper (Mark Hofmann)'

Cc:

'agc (Alan Corry)'; 'lisar'; 'billz (Bill Zuravleff)'; 'dickson (Richard Dickson)'; 'geert (Geert Rosseel)'; 'mws (Mark Semmelmeyer)'; 'woody (Jay Tomlinson)'

Subject:

Coprolite polishing

Mark Hofmann wrote (on Sun Jan 15):

Ηi,

I've got yet another version of Planet to release. This version should "only" affect merged PLAs (the new planet option). I noticed when multiple PLAs are given to Planet it is possible that they share minterms. If so, these can be merged. (Normally the input to Planet comes only from a single Espresso run and Espresso quashes redundant minterms).

So... Should I do a release?

I'll wait for resposnes.

I think we ought to think seriously about freezing the version we are using on euterpe. Even in the absense of new problems like the unexpected instance name changes, we are losing a lot of time with constantly having to regenerate things.

lisar (Lisa Robinson)

Sent:

Monday, January 16, 1995 1:15 PM

To:

Subject:

'craig'; 'lisar' Registered copy generated

Copy created by:

lisar

Copy created at:

Mon Jan 16 11:14:30 PST 1995

Copy number:

284

Copy registered to: Jim LaBarre

Input file:

/u/craig/documents/Terpsichore/Terpsichore.macps.gz.des

Output file:

/u/craig/documents/Terpsichore/Terpsichore.ps

Printed to:

rsh plotter lpr -PCraig

Recorded in file:

/u/craig/documents/RegistrationLog

[This message generated by /u/craig/bin/macpstops]

Sent:

wampler (Kurt Wampler) Monday, January 16, 1995 2:07 PM 'geert'; 'vo' Wire lengths for 99.2% route

To:

Subject:

Ηi,

The wire lengths for the 99.2% route (not including Cerberus) can be found

/n/rhodan/s2/wampler/euroute/geert\_euterpe-iter.cap

- Kurt

dbulfer (David Bulfer)

Sent:

Monday, January 16, 1995 4:05 PM

To:

'David Bulfer'

Cc: Subject: 'tbr@MicroUnity.com'; 'mnemo' Re: Mnemo generated PCI interrupts

TBR wrote on (Mon Jan 16):

Can we model this on the existing event register, where, by choice of address we have the option to do reagular writes, or bit set and bit clear operations where the data value is the mask for the bits to be set cleared?

The mechanism described in Terpsichore should be augmented for this purpose. The interrupt status has 2 customers with different requirements. The PCI bus interrupt is the logical OR of all the enable status bits.

### Pandora needs:

- a non-blocking read to get status and
- a non-blocking write to clear it.

#### Hestia needs:

- a non-blocking write to set status,
- a read that blocks until the status register is zero, and
- a write that blocks until the bitwise-AND of the write data and status register is zero.

The last two block on the opposite condition of the event register, that is, the zero rather than non-zero condition. It is this way that Hestia knows when the interrupt has been serviced.

David

tbr (Tim B. Robinson)

Sent:

Monday, January 16, 1995 5:06 PM

To:

'craig'

Cc:

'David Bulfer'; 'mnemo'

Subject:

Re: Mnemo generated PCI interrupts

Craig, can you comment on this please?

David Bulfer wrote (on Mon Jan 16):

TBR wrote on (Mon Jan 16):

Can we model this on the existing event register, where, by choice of address we have the option to do reagular writes, or bit set and bit clear operations where the data value is the mask for the bits to be set cleared?

The mechanism described in Terpsichore should be augmented for this purpose. The interrupt status has 2 customers with different requirements. The PCI bus interrupt is the logical OR of all the enable status bits.

#### Pandora needs:

- a non-blocking read to get status and
- a non-blocking write to clear it.

### Hestia needs:

- a non-blocking write to set status,
- a read that blocks until the status register is zero, and
- a write that blocks until the bitwise-AND of the write data and status register is zero.

The last two block on the opposite condition of the event register, that is, the zero rather than non-zero condition. It is this way that Hestia knows when the interrupt has been serviced.

David

mws (Mark Semmelmeyer)

Sent:

Monday, January 16, 1995 7:26 PM

To:

'euterpe'

Subject:

EUTERPE WORKING: SMux64 not to be supported

We have a bug in the current implementation that SMux64 behaves the same as SMAS64; i.e. SMux64 writes a destination register when it is not supposed to. Currently there are many other bug, squeezing, timing, placement, and routing fixes of definitively higher priority. Also the software people tell me that SMux64 is the much less useful variation of the two, because usually one wants the old load data when using a semaphore operation. Since the user can always restore SMAS64's data register to get the same effect as SMux64, SMux seems only an infrequently usable minor performance enhancement.

Thus I think we should begin expecting SMux64 to become a reserved instruction. Let's assume this becomes official Friday at noon.

mws (Mark Semmelmeyer)

Sent:

Monday, January 16, 1995 7:26 PM

To:

'euterpe'

Subject:

EUTERPE WORKING: SMux64 not to be supported

We have a bug in the current implementation that SMux64 behaves the same as SMAS64; i.e. SMux64 writes a destination register when it is not supposed to. Currently there are many other bug, squeezing, timing, placement, and routing fixes of definitively higher priority. Also the software people tell me that SMux64 is the much less useful variation of the two, because usually one wants the old load data when using a semaphore operation. Since the user can always restore SMAS64's data register to get the same effect as SMux64, SMux seems only an infrequently usable minor performance enhancement.

Thus I think we should begin expecting SMux64 to become a reserved instruction. Let's assume this becomes official Friday at noon.

Date: Mon, 16 Jan 1995 18:36:43 -0800

From: craig (Craig Hansen)

To: euterpe, mws

Subject: Re: EUTERPE WORKING: SMux64 not to be supported

smux is also useful for writing a subset of the bits of an octlet, as may occur in modifying a bit field in a structure. smux also permits (but obviously does not require) a much faster implementation, as it doesn't modify reg state and can therefore be performed with timing of stores; i.e. it can be bufferred.

It seems foolish to me to nuke the instruction just to avoid fixing a bug.

craid

Sent:

Monday, January 16, 1995 7:37 PM

To:

'euterpe mws'

Subject:

Re: EUTERPE WORKING: SMux64 not to be supported

smux is also useful for writing a subset of the bits of an octlet, as may occur in modifying a bit field in a structure. smux also permits (but obviously does not require) a much faster implementation, as it doesn't modify reg state and can therefore be performed with timing of stores; i.e. it can be bufferred.

It seems foolish to me to nuke the instruction just to avoid fixing a bug.

craig (Craig Hansen)

Sent:

Monday, January 16, 1995 8:37 PM 'euterpe'; 'mws'

To:

Subject:

Re: EUTERPE WORKING: SMux64 not to be supported

smux is also useful for writing a subset of the bits of an octlet, as may occur in modifying a bit field in a structure. smux also permits (but obviously does not require) a much faster implementation, as it doesn't modify reg state and can therefore be performed with timing of stores; i.e. it can be bufferred.

It seems foolish to me to nuke the instruction just to avoid fixing a bug.

hopper (Mark Hofmann)

Sent:

Tuesday, January 17, 1995 12:20 AM

To:

'Geert Rosseel'

Subject:

Re: Top-level Euterpe

## Geert Rosseel writes:

I build euterpe BOM 202.

- -> I moved lt between at and nd .. not pretty but it fits ..
- -> I moved the blocks in the datapath around as Rich wanted to solve the wiring congestion

mst - xlu - mc - es - gf - rg - cr

I mirrored the datapath section of es and  $\operatorname{gf}$  , but I did not mirror the control

Kurt : Can you route this one and see if it gets better ?

It's in the usual place :
/n/ghidra/s3/geert/euterpe/verilog/bsrc/gards

Hi Geert,

Okay, great. So everything in BOM 202.0 places now? (is BOM 202 the most recent BOM?)
-mark

wampler (Kurt Wampler)

Sent:

Tuesday, January 17, 1995 11:16 AM

To:

'billz', 'brianl', 'dickson', 'geert', 'hopper', 'mws', 'tbr', 'woody'

Subject: Re: Top-level Euterpe

## Geert writes:

```
> I built euterpe BOM 202.
> -> I moved lt between at and nd .. not pretty but it fits ..
> -> I moved the blocks in the datapath around as Rich wanted to
> solve the wiring congestion
> mst - xlu - mc - es - gf - rg - cr
> I mirrored the datapath section of es and gf , but I did not
mirror
> the control
> Kurt : Can you route this one and see if it gets better ?
> It's in the usual place :
> /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards
```

I've picked up the GARDS source files and will run some routing iterations.

- Kurt

woody (Jay Tomlinson)

Sent:

Tuesday, January 17, 1995 3:10 PM

To:

'geert (Geert Rosseel)'

Cc:

'billz'; 'brianl'; 'dickson'; 'hopper'; 'mws'; 'tbr'

Subject:

Euterpe timing errors

Geert Rosseel wrote (on Tue Jan 17):

Ηi,

Here are the timing violations of the latest top-level run. This is the one that has lt between at & nb, and the re-arranged datapath.

More detailed info is in :

/n/ghidra/s3/geert/euterpe/verilog/bsrc/gards/geert\_euterpe-top.stat
 (look for HARD ERROR)

The errors are in 4 areas :

- --> in uu : we know about that
- --> uu to rest of world
- --> XLU to rg now that we moved rg : I believe that with care in placement and routing, we can deal with these
- --> errors in and out nb (to/from dr, hcl, uu, cc, ..)

Jay is working on errors in uu, and Rich and I are looking at the xlu/rg path. Can anyone please look at the "nb errors" or the "uu to rest of world errors" ?

The uu->at paths are known problems. I will address this as part of the in uu problems. Once I get the 'in uu' problems under control I plan on to a real placement to make an attempt at solving some of the uu->rest\_of\_world.

Jay

craid

Sent:

Tuesday, January 17, 1995 4:38 PM

To:

'dbulfer mnemo pandora'

Subject:

Re: What does PCI reset mean to Mnemo/Hermes/Hestia I/F

What's going to generate this reset, and what state is lost? Signalling an error packet causes a Euterpe machine check, which may make bring-up sequencing more complicated.

Hestia should be asserting Cerberus reset (grounding SD) until the system is ready to come out of reset.

dbulfer (David Bulfer)

Sent:

Tuesday, January 17, 1995 5:55 PM

To:

'Craig Hansen' 'mnemo'; 'pandora'

Cc: Subject:

Re: What does PCI reset mean to Mnemo/Hermes/Hestia I/F

> What's going to generate this reset, and what state is lost?
> Signalling an error packet causes a Euterpe machine check, which may
> make bring-up sequencing more complicated.
> Hestia should be asserting Cerberus reset (grounding SD) until the
> system is ready to come out of reset.
> Craig

>

In the event the interface card is plugged into a PC, it would be some combination of the CPU and mother board.

The other possibility is a Hestia plugged into a Pandora. I would assume that someone would be driving the Cerberus to reset Euterpe & the Mnemo on the PCI bridge. But what about the Mnemo that is plugged into the PCI as a Hestia I/F? If Euterpe gets a machine check, I assume that we would like to reset the PCI bus. What does that mean to Hestia?

As far as what data is lost, at the very minimum, the PCI configuration of all devices is reset. I suspect that you'd have to reset all state machines that may be in some phase of PCI I/O. That would likely trash anything that Hestia might be doing.

David

Exhibit C10

rich (Rich McCauley)

Sent:

Tuesday, January 17, 1995 6:16 PM

To:

'graham'

Cc: Subject: 'pandora'; 'tbr'; 'rich' CMOS clocks

As of the moment, I've no plans for designing any PLLs for the CMOS version of euterpe. Both PLLs on the mobimos version are there solely for the convenience of being able to change the operating frequencies of the sofa clock and Hermes channel through software and

independently from one another. Thus, there is no need to change oscillator modules on the board to adjust the system operating frequencies. For the CMOS euterpe I would contend that it doesn't make sense to spend the design effort to implement PLLs at this time. The required clocks can be generated outside the chip either through an external PLL or simply with a clock module. I believe this is the right way to go, but I think we need to air this issue and agree on a course of action.

If my suggestion is adopted, board space will need to be allocated. Comments?

rich

tbr (Tim B. Robinson)

Sent:

Tuesday, January 17, 1995 7:29 PM

To:

'dbulfer (David Bulfer)'

Cc:

Craig Hansen; 'mnemo'; 'pandora'

Subject:

Re: What does PCI reset mean to Mnemo/Hermes/Hestia I/F

David Bulfer wrote (on Tue Jan 17):

> What's going to generate this reset, and what state is lost?
> Signalling an error packet causes a Euterpe machine check, which
> may make bring-up sequencing more complicated.
> Hestia should be asserting Cerberus reset (grounding SD) until
> the system is ready to come out of reset.
> Craig

In the event the interface card is plugged into a PC, it would be some combination of the CPU and mother board.

The other possibility is a Hestia plugged into a Pandora. I would assume that someone would be driving the Cerberus to reset Euterpe & the Mnemo on the PCI bridge. But what about the Mnemo that is plugged into the PCI as a Hestia I/F? If Euterpe gets a machine check, I assume that we would like to reset the PCI bus. What does that mean to Hestia?

As far as what data is lost, at the very minimum, the PCI configuration of all devices is reset. I suspect that you'd have to reset all state machines that may be in some phase of PCI I/O. That would likely trash anything that Hestia might be doing.

This raises anothour issue. We have been assuming that we can use the same Cerberus for both Pandora and Hestia, using the multi-master capability. Either side then can explicitly reset chips on the other side by writing the appropriate reset bit in octlet 6 in the target device. However, we will not be able to use the blanket reset by holding SD down without resetting both systems. Do we have any concern that Hestia may get sufficiently hosed that this is the only way (short of cycling the power) to reset it? This should not be the case in the absense of hardware bugs because the Cerberus slave operation should not be dependent on software activity. However, if we felt it was a requirement, then some sort of isolation would be needed.

tbr (Tim B. Robinson)

Sent:

Tuesday, January 17, 1995 9:38 PM

To: Cc: 'rich (Rich McCauley)'
'graham'; 'pandora'; 'rich'

Subject:

**CMOS** clocks

Rich McCauley wrote (on Tue Jan 17):

As of the moment, I've no plans for designing any PLLs for the CMOS version of euterpe. Both PLLs on the mobimos version are there solely for the convenience of being able to change the operating frequencies of the sofa clock and Hermes channel through software and independently from one another. Thus, there is no need to change oscillator modules on the board to adjust the system operating frequencies. For the CMOS euterpe I would contend that it doesn't make sense to spend the design effort to implement PLLs at this time. The required clocks can be generated outside the chip either through an external PLL or simply with a clock module. I believe this is the right way to go, but I think we need to air this issue and agree on a course of action. If my suggestion is adopted, board space will need to be allocated.

Comments?

I think I agree with this approach. To the extent that the operating

frequency will be a lot lower than the ECL version we are unlikely to want to operate the Hermes channels more slowly than the CPU, so extra flexibility there is pointless. So long as we would be able to arrange the external clock source to be slaved off a reference which could be the reference output from Calliope we would be able to interwork OK.

hopper (Mark Hofmann)

Sent:

Wednesday, January 18, 1995 12:21 AM

To: Cc: Subject: 'Richard Dickson'
'geert (Geert Rosseel)'
Re: rich\_euterpegards

Richard Dickson writes:

geert or mark,

i'm stuck ...
i was running rich\_euterpegards and it failing and i dont see it ???
see gards.log in my euterpe/verilog/bsrc dir

i was trying ctioi cp cj and iq in my place and route attempt fist time. i just added cp. it worked with ctioi cj and iq.

Hi Rich,

Sorry for the late reply, In the make.log the last lines read: /n/rama/s5/dickson/euterpe/tools/bin/pim2pif: Processing the gards/rich\_euterpe-iter.pim file... /n/rama/s5/dickson/euterpe/tools/bin/pim2pif: In pim section 2 couldn't find .mo reObstructions ../ctioi/ctioi-base.obs Exiting...

In
 gards/rich\_euterpe-iter.pim

there is the line

.moreObstructions ../ctioi/ctioi-base.obs

But Pim2pif can't find the file ../ctioi/ctioi-base.obs to open for reading, so it Exits. Probably this file is not under CVS control and somebody forgot to check it in. You might be able to do a CVS update on the ctioi directory, of just copy it from /u/chip/... to your local area.

-hopper

tbr (Tim B. Robinson)

Sent:

Wednesday, January 18, 1995 1:37 AM

To:

'bobm' 'euterpe'

Cc: Subject:

Euterpe Octlet 31

We need to clarify the documentation for Euterpe Cerberus octlet 31 please.

- 1. Bits 47:43 There is no doubling of this value. The actual clock frequency on the Hermes channel is this number times the reference frequency.
- 2. Bits 39:35 Clarify the doubling. For a PLLO divide ratio value of <n> the sofa clock frequency will be 2<n> times the reference. (This is largely historical and comes from the fact that we used to use a clock which was active on both edges, but was then changed to be active only on a single edge at double the frequency.)
- 3. Note needed. If one PLL is bypassed, so must the other be. Operation is undefined if one PLL is bypassed and the other is not.
- 4. Note needed. When the PLLs are bypassed, the only legal values for the divide ratio fields are 5 for PLL1 divide ratio and 10 for PLL0 divide ratio. In this case the Sofa clock frequency will be equal to the supplied reference frequency and the Hermes frequency will be half that. (This restriction is not strictly necessary, but it's harder to explain whats really going on. The true restriction is that PLL1 divide ratio must be <= 5 and PLL0 divide ratio must be >= 6. However, whatever values are chosen subject to this restriction, the actual clock frequencies used will be the same.)
- 5. The asterisks for bits 47:43, 42, and 41 should be removed.

dickson (Richard Dickson)

Sent:

Wednesday, January 18, 1995 2:10 AM

To: Subject: 'geert'; 'hopper' rich\_euterpegards

geert or mark,

i'm stuck ...
i was running rich\_euterpegards and it failing and i dont see it ???
see gards.log in my euterpe/verilog/bsrc dir

i was trying ctioi cp cj and iq in my place and route attempt fist time. i just added cp. it worked with ctioi cj and iq.

dickson

wampler (Kurt Wampler)

Sent:

Wednesday, January 18, 1995 10:55 AM

To: Cc: 'vo' 'geert'

Subject:

killed pgroute

After reporting its inability to route PHI\_A2P over to the XCDECSW cell in Cerberus, my PGROUTE didn't seem to get any further. I let it run all night, and when I came in this morning, it hadn't gotten any further, and hadn't touched the dff since yesterday at 11:40AM. So I killed it. Hopefully moving the XCDECSW cell will cure the problem, but it would be good to do this soon and confirm that we can indeed get a good PGROUTE of euterpe.

- Kurt

billz (Bill Zuravleff)

Sent:

Wednesday, January 18, 1995 11:50 AM

To: Cc: 'wampler (Kurt Wampler)' 'geert (Geert Rosseel)'

aplace r

Subject:

gplace read only?

## Kurt,

I was using gplace to examine components and nets of global timing violations in the snapshot area - /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards.

I use the following command to invoke gplace - invoke gplace geert\_euterpe-iter -inbat 0 &

and exit with "exit nosave" menu option. I was just nervous that this procedure wrote any files whatsoever. I assume if I clobbered some crucial design file, I'd hear about it. Is there a way to invoke gplace, read only, or should I not worry about this?

Thanks, billz

wampler (Kurt Wampler)

Sent:

Wednesday, January 18, 1995 11:58 AM

To: Cc: 'billz' 'aeert'

Subject:

Re: gplace read only?

### Bill Z. writes:

> I was using gplace to examine components and nets of global timing
>violations in the snapshot area >/n/ghidra/s3/geert/euterpe/verilog/bsrc/gards.
>I use the following command to invoke gplace - invoke gplace
>geert\_euterpe-iter -inbat 0 &
>

>and exit with "exit nosave" menu option. I was just nervous that this
>procedure wrote any files whatsoever. I assume if I clobbered some
>crucial design file, I'd hear about it.
>Is there a way to invoke gplace, read only, or should I not worry about
>this?

As far as I know, there's no way to invoke gplace in "readonly mode". What

you did was "safe" in that the exit-nosave-nopof option will not write anything in the dff. If you used just exit-nosave, then it rewrites the pof (placement output file) upon exit, but still doesn't update the dff. GPLACE always writes an output listing file (defaults to gplace.lis, but may be renamed), and typically updates the ".vrf" file and a file called "invoke.com".

When I want to view someone else's design in with gplace or redit, I use the following procedure:

mkdir scratch cd scratch

ln -s

/n/ghidra/s3/geert/euterpe/verilog/bsrc/gards/geert\_euterpe-iter.dff .
cp /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards/geert\_euterpe-iter.vrf

ln -s /u/chip/technology/mobimos/gards/\*234 .
(edit the vrf and change the "colorin" parameters for gplace & redit to
 point to these links: gplace.mobi234 & redit.mobi234 respectively).
then invoke gplace or redit

Since you're in the same group as geert, and since his dff files seem to be group-writable, there is no OS protection against accidentally trashing his files, so...be careful. :-)

- Kurt

Sent: Wednesday, January 18, 1995 1:04 PM 'rich'; 'tbr' To: 'pandora' Cc: Re: CMOS clocks Subject: I also agree with this approach. I would point out, however, that Tim's suggestion about use of Calliope as a reference clock source is undesirable, since digital-only Pandora systems may not require Calliope to provide I/O. Separate clock arrangements would then have to be made for the CMOS Euterpe. > From tbr Tue Jan 17 19:37:40 1995 > Date: Tue, 17 Jan 1995 19:37:34 -0800 > From: tbr (Tim B. Robinson) > To: rich (Rich McCauley) > Cc: graham, pandora, rich > Subject: CMOS clocks > Content-Length: 1342 > Rich McCauley wrote (on Tue Jan 17): As of the moment, I've no plans for designing any PLLs for the > CMOS version of euterpe. Both PLLs on the mobimos version are there solely for the convenience of being able to change the operating frequencies of > the sofa clock and Hermes channel through software and independently from > one Thus, there is no need to change oscillator modules on the board to adjust the system operating frequencies. For the CMOS euterpe I would contend that it doesn't make sense to spend the design effort to implement PLLs this The required clocks can be generated outside the chip either time. through an external PLL or simply with a clock module. I believe this is the right way to go, but I think we need to air this issue and agree on a course > of action. If my suggestion is adopted, board space will need to be allocated. Comments? > I think I agree with this approach. To the extent that the operating > frequency will be a lot lower than the ECL version we are unlikely to > want to operate the Hermes channels more slowly than the CPU, so extra > flexibility there is pointless. So long as we would be able to > arrange the external clock source to be slaved off a reference which > could be the reference output from Calliope we would be able to > interwork OK. > Tim

graham (Graham Y. Mostyn)

From:

stick (Bruce Bateman)

Sent:

Wednesday, January 18, 1995 1:10 PM

To: Cc: 'michael' 'euterpe'

Subject:

Re: Huns models

Chris Michael previously said:

People,

I've updated the Huns MOS models to align with the information provided in their design rules. The devices described in the design rules bear absolutely no resemblance to our previously modeled devices (time to re-simulate everything).

The mobi-like format for NMOS and PMOS devices can be found in the following library:

.lib '/u/chip/technology/huns/hspice/models.lib' huns\_60

Right now, the library contains only the models for nominal NMOS and PMOS transistors. These models are still Level 3; therefore, they'll still have kinks and poor length and narrow width scaling.

Things these models should reflect fairly accurately:

- basic device I-V parameters (Idsat, Vt)
- device capacitances (Cgate, Cj, Cgd/Cgs)

Things these models will probably have problems with:

- Current scaling with gate length (or narrow widths)
- Output conductance
- Transition from linear to saturation
- Basic I-V accuracy (it fits to Idsat and Vt but otherwise??)
- Temperature dependence (not much information in the design rules)

Chris

-----

I guess that I'm a little confused here. Are these "new" models that have been fit to the CMOS14 data that the huns gave us last week?

Or are you saying that they are just a tweek of the old huns BiCMOS models that were already on the system? If this is the case, are you saying that their old models bare some resemblance to their current CMOS14 transistors?

BB

michael (Chris Michael)

Sent:

Wednesday, January 18, 1995 1:29 PM

To:

'Bruce Bateman'

Cc:

'euterpe'

Subject:

Re: Huns models

#### Bruce Bateman wrote:

>

- > I guess that I'm a little confused here. Are these "new" models that
- > have been fit to the CMOS14 data that the huns gave us last week?

The models I released yesterday are just crude fits to the data the huns provided in their design rules.

- > Or are you saying that they are just a tweek of the old huns BiCMOS
- > models that were already on the system?

I did start with their old models - but I had to change over half of the parameters (Vt, DL, DW, tox, Cgs, Cgd, Cj, Rs, Rd ...) to arrive at a model which approximates their new CMOS14 process. Luckily, this is rather simple to do with Level 3 models (well, it's much easier than BSIM2).

- > If this is the
- > case, are you saying that their old models bare some resemblance to
- > their current CMOS14 transistors?

The only resemblance is that the minimum drawn L is still 0.6um and they're still MOS devices. I'd say that everything else has changed.

Eventually, the Huns will provide us with full-blown BSIM2 models.

Chris

doi (Derek Iverson)

Sent:

Wednesday, January 18, 1995 1:53 PM

To:

'guarino'; 'sandeep'; 'gmo'; 'jeffm'; 'wayne'

Cc:

'hestia'

Subject:

Software Bringup Meeting Minutes - January 18, 1995

Software Bringup Meeting January 18, 1995

Next Meeting:

January 25 at 10:00 am.

Attendees: jeffm, guarino, wayne, gmo, sandepp, doi

New Action Items

Item: Rerun dcacheharder and icacheharder tests and get cycle count

results.

Who: doi

Status:

[01/11] New.

The dcacheharder and icache harders tests should run now.

Review of Action Items

Item: More investigation on CBI and workstation interface issues.

Who: guarino, wayne

Status:

In limbo for a day or so....

There needs to be some decisions made as to whether or not this work is going to occur.

Item: Implement parallel port device driver for Linux on PC.

Who: jerry, doi

Status: [12/14] In progress.

Item: Define and implement a snapshot environment for the HW and SW

simulators.

Who: jeffm, gmo, guarino

Status:

[11/30] In progress

Jeff showed us first cut at his high-level thoughts. The team will review and supplement the proposal.

Item: Continue trying to find either source code for parallel drivers

or descriptions of hardware so we can write out own.

gmo sgi machines Who:

sun machines Who: doi

[11/23] Progress continues. Status:

> Called Aurora (company suggested by Avcom) and have pestered them daily trying to get anwers.

Item: Build scripting/UI capabilities above gdb for regression tests.

Who: doi

Status: on hold until the the boot, gdb boot stub, and virtual devices

are complete.

Item: Create performance test plan

Who: jeffm, guarino

Status: [11/30] No progress this week as focus was on functionality.

We continue to run tests to help us compare terp vrs hardware

performance.

We still need to put together the actual performance tests that

need to be run on the hardware.

Item: Simulator needs to understand `reset'

Who: gmo

Status: [11/30] In progress. Target finish of 1/20.

Item: Implement and bring-up boot, gdb boot stub, and virtual device

support on the software simulator.

Who: sandeep/gmo

Status: In progress. Target finish of [1/10] 1/20.

Booting the microkernel should be finished by 1/20.

The ability to boot arbitrary code supplied by gdb is expected

by 1/17.

Completed Items

Who: doi

Status: [01/11] Done.

The test was unable to run with the current BOM.

Item: Run dcacheharder test and get cycle count results.

Item: Add Unix-like tests to software acceptance tests.

Who: iimura

Status: [11/30] Done.

Test Status

Jeff talked about test and debug status.

From: Sent: Gregg Kellogg [gregg@hts.microunity.com] Wednesday, January 18, 1995 2:10 PM

To:

'lisa'

Subject:

execute\_loop hit a notdecoded instruction

I ran ~gregg/stb/apps/tv/tv.reg (which uses "tv" and "../../ukernel/ukernel" binaries). This simulator ran for a simulated 56 ms and resulted in the following output:

0.676932 ms(ao=0):NO SIGNAL: wait for message 0.923956 ms(ao=0):ACQUIRE PAT: wait for PAT 0.979863 ms(ao=0):ACQUIRE PAT: new PMT PID 2 1.024206 ms(ao=0):ACQUIRE PMT: wait for video PID 1.063743 ms(ao=0):ACQUIRE PMT: new video PID 16 1.110039 ms(ao=0):INIT VIDEO: decode video

56.099159 ms(ao=0):INIT VIDEO: Initialize DLWS execute\_loop hit a notdecoded instruction

If you copy tv, kernel, and tv.reg anyplace else and run tv.reg it should give you the same results.

I have the same thing running with the stb-stable/bin/terp and it's run for over 130 ms.

Gregg Kellogg
MicroUnity Systems Engineering, Inc.
255 Caspian Drive, Sunnyvale, Ca 94089-1015 gregg@microunity.com

jeffm (Jeff Marr)

Sent:

Wednesday, January 18, 1995 5:11 PM

To:

'euterpe'; 'hestia'

Subject:

Simulation State Snapshots - heterogeneous environments

There are several reasons to want to be able to transfer high-level machine state between different environments. The transfer that would be desirous NOW is from terp (the instruction level simulator) to HW simulation (verilog, zycad, and ikos) environments.

We will be running the Euterpe Ukernel Tests and the Unix Kernel in HW simulation. Running the Unix Kernel, even on the IKOS box, as a monolithic hunk of SW would take about 3 days. Also, the Ukernel Tests all go though essentially identical initialization sequences that don't need to be repeated all the time. It is desirous to run the SW to certain points on terp, and transfer the "state" to the HW simulation environments.

Obviously, entire state information cannot be transfered, but it is possible to transfer an "architectural" snapshot of of the state. Below, I describe what I think is required to do this.

In zycad and verilog simulation environments we can (if not now, soon) preload the following  ${\tt HW}$  structures:

dram, rom, cerb registers, tag, buffer, gtlb, register file.

Gtlb and register files are not loadable on the IKOS, however.

If we assume that IKOS is our primary target, it means that the following are not preloadable:

calliope interface state (event daemon armed/disarmed)

5 X pc and priv (gmo - could always limit to high priv.)

event mode (gmo - could always limit to event mode.)

system registers(timer, timer match, event regiser, event mask,

etc.)

event daemons/calliope state

gtlb, ltlb

register files

Euterpe SW running on terp would need to save the state of the registers and structures mentioned above into a preloadable place (dram or dbuffer), or terp itself would need to save them directly. If terp does it, the saved data will need to be put into the dram or dbuffer preload files . Gmo feels that that the mkimg tool can do that, and also has expressed his preference that terp dump out state in elf format. On the HW simulator side, Euterpe SW would need to grab the values from their saved places and "unsnap" the state.

The sequence would be:

Snap: (on terp)

(Squirrel === put in dram or dbuffer). Squirrel away the state of cerb registers 6, 7, 10. (more?) Squirrel away the pc and priv + state of event mode (how know?).

Squirrel away the state of the event mask, the ltlb.

Squirrel away the Calliope interface state (daemon armed, disarmed).

Keep pointers to same.

Dump dram, tag, buffer, gtlb, register file (elf format).

Process dump information: (shell)

Blow up dump into preload files (dram, dbuffer, tag, etc.).

(mkimg)

Unsnap: (on hw simulator)

Load dram, tag, buffer, gtlb, register file. Reload squirreled away info. branch to squirreled away pc's.

### Notes:

No changes required to HW simulator environments.

Does not account for Calliope state.

There is another snapshot that is not addressed here - from a bringup box back to a simulation environment. Many of the same principles apply.

tbr (Tim B. Robinson)

Sent:

Wednesday, January 18, 1995 7:16 PM

To:

'graham (Graham Y. Mostyn)'

Cc: Subject: 'pandora'; 'rich' Re: CMOS clocks

Graham Y. Mostyn wrote (on Wed Jan 18):

I also agree with this approach. I would point out, however, that Tim's suggestion about use of Calliope as a reference clock source is undesirable, since digital-only Pandora systems may not require Calliope to provide I/O. Separate clock arrangements would then have to be made for the CMOS Euterpe.

We are making provision for a separate 54MHz reference when there is no Calliope. Hoever, if there is a Calliope, it's essential we can run everything from a single reference or the Hermes channels will not function. Assumeing we still want the cleanest possible clock to Calliope, we must then be able to generate the CMOS euterpe clock from the 54MHz Calliope output.

tbr (Tim B. Robinson)

Sent:

Wednesday, January 18, 1995 7:23 PM

To: Cc:

'tbe' 'pandora'

Subject:

Euterpe module form factor

We need to be sure that we will be able to fit the CMOS Euterpe module into the Pandora backplane. The form factor I have seen for the module based on the ECL Euterpe version looks tight. Although we do not yet know what the packaging for the CMOS version will be, we do know the die will be much bigger, so it would be wise to be conservative in allowing spare board area. It's possible we may not be supporting the SDRAM interface on the CMOS version, which would give us some free board space in the long dimension, but we should not count on that. The narrow dimension could be a problem.

We may need to accommodate additional components on the CMOS version (eg a separate PLL or clock buffer devices).

What is the advantage in making this board narrower than the Mnemosyne module?

tbr (Tim B. Robinson)

Sent:

Wednesday, January 18, 1995 7:42 PM

To:

craig'

Cc: Subject: 'euterpe'; 'dickson' Cerberus octlet 6

We may have something wrong in Cerberus octlet 6. Bits 62 and 63 are the logic clear and circuit reset respectively. These bits have a default value of 1 right now, and retain that value after reset completes. (It's the bits in octlet 7 that actually show when the reset is active or completed.) So, if you do a read modify write to set some other field you have to explicitly mask off these bits or you get a reset when you store the value back. It is the act of writing to octlet 6 with one of these bots set that actually triggers the reset, not the static level of the bit. So would it make more sense if these bits always returned 0 on a read?

tbr (Tim B. Robinson)

Sent:

Wednesday, January 18, 1995 7:54 PM

To:

'hopper (Mark Hofmann)'

Cc:

'hardheads'

Subject:

New verison of Planet released

Mark Hofmann wrote (on Wed Jan 18):

I have released a new version of Planet which warns of unused inputs and exits with a fatal error if undriven outputs are detected. A case of undriven (but subsequently used) outputs was found in the CC section of Euterpe. This error would presumably have been caught by simulation. Planet now provides an early warning.

It should also have been caught by csyn, but the only floating inputs fred refers to in the last report wer tau inputs which I doubt should have been driven from a PLA. Fred, can you check on this please.

Tim

Tom Eich [tbe@MicroUnity.com]

Sent:

Wednesday, January 18, 1995 8:38 PM

To:

'Tim B. Robinson'

Cc: Subject: 'pandora@MicroUnity.com'
Re: Euterpe module form factor

>We need to be sure that we will be able to fit the CMOS Euterpe module >into the Pandora backplane. The form factor I have seen for the module >based on the ECL Euterpe version looks tight. Although we do not yet >know what the packaging for the CMOS version will be, we do know the >die will be much bigger, so it would be wise to be conservative in >allowing spare board area. It's possible we may not be supporting the >SDRAM interface on the CMOS version, which would give us some free >board space in the long dimension, but we should not count on that. >The narrow dimension could be a problem.

>We may need to accommodate additional components on the CMOS version >(eg a separate PLL or clock buffer devices).

>What is the advantage in making this board narrower than the Mnemosyne >module?

>Tim

No advantage any longer; at one time, there might have been one in terms of packaging efficiency at the box level, but with Calliope modules looking like mnemo modules, there is none now. I'll update the layout accordingly and re-distribute it.

-Tom

Tom Eich

MicroUnity Systems Engineering, Inc. 255 Caspian Dr. Sunnyvale, CA 94089 (408)734-8100, (408)734-8136 fax

tbe@microunity.com

tbr (Tim B. Robinson)

Sent:

Wednesday, January 18, 1995 8:43 PM

To: Cc: 'jeffm (Jeff Marr)' 'euterpe'; 'hestia'

Subject:

Simulation State Snapshots - heterogeneous environments

Jeff Marr wrote (on Wed Jan 18):

There are several reasons to want to be able to transfer high-level machine state between different environments. The transfer that would be desirous NOW is from terp (the instruction level simulator) to HW simulation (verilog, zycad, and ikos) environments.

We will be running the Euterpe Ukernel Tests and the Unix Kernel in HW simulation. Running the Unix Kernel, even on the IKOS box, as a monolithic hunk of SW would take about 3 days. Also, the Ukernel Tests all go though essentially identical initialization sequences that don't need to be repeated all the time. It is desirous to run the SW to certain points on terp, and transfer the "state" to the HW simulation environments.

I would like a better understanding of what the real need is here. We have the ability to checkpoint the hardware simulator, which gives us the basic ability to save the state after a fixed initialization sequence and pick up from there. When we are trying to run the unix kernel, are we saying that we never want to try the early stages on the hardware or that for some reason we would not do that till we knew the later stages would work? If we do want (eventually) to be able to get from startup to prompt, and if we are willing to debug things from the front forward as we go, then we can use the same checkpointing.

However, if as a result of this exercise we are unlucky enough to still be finding a sigificant number of bugs (in the hardware, as opposed to the simulation scaffolding or the software we are trying to run), then one might consider there is something to be saved by being able to start a hardware simulation from an advanced point after compiling in a hardware change. But, I would say this overlooks the basic fact that at that late stage in the game we should not be willing to ship the chip after making any change without rerunning a full regression test. More likely, we will be doing a detailed analysis of the problem and deciding if there is an acceptable software workaround which allows us to proceed without changing the hardware (ie until the second rev). Given this, the ability to avoid re-running initialization code, which presumably represents a relatively critical piece of code that we must have confidence will run, seems moot to me. If we do not change the hardware, we could restart from a hardware checkpoint. If we do, we should rerun from the start.

Obviously, entire state information cannot be transfered, but it is possible to transfer an "architectural" snapshot of of the state. Below, I describe what I think is required to do this.

This could be critical. We are well aware that the really subtle bugs are the ones that only show up for particular conjunctions of events between the cylinders, or between the main pipe and the memory system, and where apparantly identical code works just fine in very slightly modified timing circumstances. So, if the goal is to try to ensure we do not have any killer problems lurking in there from the kernel's point of view, we have to be willing at some point to run for real with no cheating. From a hardware perspective, the programmer visible state of the machine is but a tiny fraction of the true state of the hardware.

So, some questions:

Are we sure that the cumulative amount of time saved by having this capability will offset the time we will spend getting the full path working? We need all hands on debugging the chip right now, not the scaffolding.

Can we reduce this to a bootstrap loader which relies on nothing more than the ROM and

DRAM state to restart? These are the only things in the real systemm that we guarantee across a reset, so a solution that directly saves and restores the on chip memory images creates some exposure. While we have been using the ability to preload these arrays extensively in the early phases of verification and debug we cannot allow ourselves to do that at the end. The only acceptable final verification must run from the unmodified netlist with everything operating as it will for real.

Tim

Sent:

Buffalo Chip [chip@rhea] Wednesday, January 18, 1995 9:34 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/gt BOM 68.0 initiated by brianl completed @ Wed Jan 18 19:29:31 PST 1995 with exit status 0.. chip

hopper (Mark Hofmann)

Sent:

Thursday, January 19, 1995 4:36 AM

To:

'Geert Rosseel'

Subject:

Re: Freezing design rules

Geert Rosseel writes:

Hi Paul,

We are getting close to finishing Euterpe and we need to finalize the design rules. We want to do that by tomorrow Jan. 20.

We will assume that the current DRC flow is the final one. If there are any additions that you want to make, can you do that before the weekend? We are currently editing the layout of Euterpe to make it pass the current DRC flow.

Thank's Geert

Thanks for sending this mail, Geert.

I reminded Paul yesterday about the freeze, but he had some loose ends still to clear up.

-mark

Sent:

Buffalo Chip [chip@rhea] Thursday, January 19, 1995 6:03 AM

To:

'geert@rhea'

Subject:

pager log message

page from chip to geert: Release euterpe/verilog/bsrc/hc BOM 78.0 initiated by woody completed @ Thu Jan 19 04:00:55 PST 1995 with exit status 0.. chip

wampler (Kurt Wampler)

Sent:

Thursday, January 19, 1995 9:17 AM

To: Cc: 'geert'; 'tom'; 'vo' 'hopper'; 'tbr'

Subject:

PGROUTE endless loop

Looks like the current placement of euterpe (even with Tom Vo's adjustments to the XCDECSW cells in Cerberus) is putting PGROUTE into an endless loop.

I'm going to try resurrecting an earlier version of PGROUTE that had specific patches to deal with a TAR we submitted on a similar problem about a year ago and see if it works any better. The current PGROUTE has been running for 17 hours, and hasn't updated the .dff since 3:55PM yesterday.

I was afraid this might fall through a crack; Patrick Fitzgibbon, the programmer who did the PGROUTE fixes for us last winter/spring confirmed for me back in September that his final fixes hadn't made it in to the 7.115

release, and then he left the company. I will call SVR to find out whether his fixes made it into the upcoming 7.117 release. If they disavow all knowledge, I may need to provide them with a current test case. We never officially accepted closure on our TAR#1573 when this problem originally manifested itself. The patches that Patrick did were sufficient to let us PGROUTE Calliope, though.

- Kurt

dbulfer (David Bulfer)

Sent:

Thursday, January 19, 1995 9:27 AM

To:

'Tom Eich'

Cc:

'tbr (Tim B. Robinson)'; 'pandora'

Subject:

Re: Euterpe module form factor

> >We need to be sure that we will be able to fit the CMOS Euterpe > >module into the Pandora backplane. The form factor I have seen for > > the module based on the ECL Euterpe version looks tight. Although we > >do not yet know what the packaging for the CMOS version will be, we > >do know the die will be much bigger, so it would be wise to be > >conservative in allowing spare board area. It's possible we may not > >be supporting the SDRAM interface on the CMOS version, which would > >give us some free board space in the long dimension, but we should > >not count on that. The narrow dimension could be a problem. > > We may need to accommodate additional components on the CMOS version > > (eg a separate PLL or clock buffer devices). > >What is the advantage in making this board narrower than the > >Mnemosyne module? > >Tim > No advantage any longer; at one time, there might have been one in > packaging efficiency at the box level, but with Calliope modules > looking like mnemo modules, there is none now. I'll update the layout accordingly > and re-distribute it. > -Tom

I'm not sure how Euterpe size is affected by Calliope, but ...

Mnemo has considerablaly more board size that Euterpe. Calliope wants to be Mnemo sized or more (130x170). Current models of Euterpe have a much smaller board size (90x135). Wouldn't it make the mechanicals easier if all bricks had the same X and Y dimensions and varied in width only, preferably in quanta of one Mnemo unit (1 mu)?

David

David Bulfer

email: dBulfer@MicroUnity.Com

SnailMail: MicroUnity Systems Engineering, Inc.

408-734-8590 x282 Phone: FAX: 408-734-8136

255 Caspian Drive Sunnyvale CA 94089-1015

sysadm@gaea on behalf of Guillermo A. Loyola [gmo@MicroUnity.com]

Thursday, January 19, 1995 10:52 AM

Sent:

'euterpe@gaea'

tbr@gaea.microunity.com (Tim B. Robinson) writes:

- |>
- > We may have something wrong in Cerberus octlet 6. Bits 62 and 63 are
- > the logic clear and circuit reset respectively. These bits have a
- > default value of 1 right now, and retain that value after reset
- > completes. (It's the bits in octlet 7 that actually show when the
- > reset is active or completed.)

So the documentation should be changed. Currently both the TSA and the EMA manuals say that software is supposed to read octlet 6 to determine the cause of a reset.

- > So, if you do a read modify write to
- > set some other field you have to explicitly mask off these bits or
- > you get a reset when you store the value back.

Under the current description, osftware should set them to zero after it has read them.

- > It is the act of
- > writing to octlet 6 with one of these bots set that actually triggers
- > the reset, not the static level of the bit. So would it make more
- > sense if these bits always returned 0 on a read?

Yes, it seems better to me to make them return always zero.

Gmo.

Sent:

Geert Rosseel [geert@rhea] Thursday, January 19, 1995 11:22 AM

To:

Subject:

'geert@rhea'
pager log message

page from geert to geert:
Thu Jan 19 09:19:09 PST 1995
/N/auspex/root/s41/euterpe-snapshot/euterpe/verilog/bsrc chip\_euterpe crashed. geert

craio

Sent:

Thursday, January 19, 1995 11:27 AM

To:

'tbr'

Cc:

'dickson euterpe'

Subject: Re: Cerberus octlet 6

On Mnemosyne, and I assume Calliope as well, the part was to stay in reset or clear until the corresponding bit was explicitly cleared (set to zero). Clearly, Euterpe must automatically come out of reset and clear, and in such a case, the Cerberus bits should be cleared by the end of the operation.

Craig

hchu (Herman Chu)

Sent:

Thursday, January 19, 1995 11:34 AM

To: Cc:

'tbe' 'pandora'

Subject:

Euterpe module form factor

Please bear in mind that the cooling scheme for the CMOS version might be completely different from our Eu, since the power of the CMOS is estimated at 150 watts. The volume needed for cooling might be significantly larger than the CMOS version. I am still waiting on inputs from Tim and Geert on the junction temperature that they would like to see us achieve, in order to size a cooling system that will meet that target junction temperature.

---- Begin Included Message -----

>From tbr Wed Jan 18 17:22:47 1995 Date: Wed, 18 Jan 1995 17:22:36 -0800

From: tbr (Tim B. Robinson)

To: tbe cc: pandora

Subject: Euterpe module form factor

Content-Length: 798

We need to be sure that we will be able to fit the CMOS Euterpe module into the Pandora backplane. The form factor I have seen for the module based on the ECL Euterpe version looks tight. Although we do not yet know what the packaging for the CMOS version will be, we do know the die will be much bigger, so it would be wise to be conservative in allowing spare board area. It's possible we may not be supporting the SDRAM interface on the CMOS version, which would give us some free board space in the long dimension, but we should not count on that. The narrow dimension could be a problem.

We may need to accommodate additional components on the CMOS version (eg a separate PLL or clock buffer devices).

What is the advantage in making this board narrower than the Mnemosyne module?

Tim

---- End Included Message -----

Sent:

geert (Geert Rosseel) Thursday, January 19, 1995 11:42 AM

To: Cc: 'hchu'; 'tbe' 'pandora'

Subject:

Re: Euterpe module form factor

Our current power estimate for Cronus ( = CMOS Euterpe) is closer to 100 W. We've changed to a 3.3 V process from a 5V process.

We will do our design so that it works for a junction temperature of 127 degrees.

Geert

craig (Craig Hansen)

Sent:

Thursday, January 19, 1995 12:27 PM

To:

'tbr'

Cc:

'dickson'; 'euterpe'

Subject: Re: Cerberus octlet 6

On Mnemosyne, and I assume Calliope as well, the part was to stay in reset or clear until the corresponding bit was explicitly cleared (set to zero). Clearly, Euterpe must automatically come out of reset and clear, and in such a case, the Cerberus bits should be cleared by the end of the operation.

Craig

sysadm@gaea on behalf of Sandeep Nijhawan [sandeep@MicroUnity.com]

Sent:

Thursday, January 19, 1995 12:33 PM

To:

'euterpe@gaea'

>|> It is the act of

> > writing to octlet 6 with one of these bots set that actually

>|> triggers the reset, not the static level of the bit. So would it

> | > make more sense if these bits always returned 0 on a read?

>Yes, it seems better to me to make them return always zero.

 ${\tt Hmm...}$  If these bits are always read as zero how do we distinguish reset from logic clear from machine check ?

Currently the boot code looks at the reset bit in oct 6 and if it finds it set and the clear bit not set it assumes a power-on reset and so turns up the knobs and then sets the clear bit (while zeroing the reset bit).

The second time around it should find just the clear bit set and it simply

zeros it and proceeds with the boot sequence. If both bits are zero it assumes a machine check (as per the TSA). It uses the bits in oct 7 just to make sure the reset or logic clear has completed successfully.

I don't see why having to make sure these bits are zero while writing to oct 6 is so bad.

Sandeep

Sent:

Buffalo Chip [chip@rhea] Thursday, January 19, 1995 1:26 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/icc BOM 24.0 initiated by woody completed @ Thu Jan 19

11:23:36 PST 1995 with exit status 0.. chip

hchu (Herman Chu)

Sent:

Thursday, January 19, 1995 6:17 PM

To: Cc: 'tbe'; 'geert' 'pandora'; 'hchu'

Subject:

Re: Euterpe module form factor

```
> From geert Thu Jan 19 09:42:21 1995
> Date: Thu, 19 Jan 1995 09:42:19 -0800
> From: geert (Geert Rosseel)
> To: hchu, tbe
> Subject: Re: Euterpe module form factor
> Cc: pandora
> Content-Length: 253
>
> Our current power estimate for Cronus ( = CMOS Euterpe) is closer to > 100 W. We've changed to a 3.3 V process from a 5V process.
> We will do our design so that it works for a junction temperature of > 127 degrees.
>
```

Geert

>

With the reduced power (from 150 watts to 100 watts), relaxed junction temperature requirement and larger die size (I am using 10cm x 10cm in my calculations). We can use the same new Eu heat sink design. We might be able to do better with the junction temperature than 127 deg C (I assume we are talking about deg C, not deg F) at the worst environmental conditions.

Herman

vijay@MicroUnity.com

Sent:

Thursday, January 19, 1995 6:41 PM

To: Cc: 'tbe@MicroUnity.com'; 'noel@MicroUnity.com'; 'dbulfer@MicroUnity.com'

'vijay@MicroUnity.com'; 'pandora@MicroUnity.com'

Subject:

Micropax availability

Just found out about the avialabilty of the various positions and flavors on the Micropax connector.

80 pin-- vertical thru hole, vert surface mount, straddle mount.

100 pin-- vertical surface mount

120 pin-- vertical surface mount

160 pin-- vert thru hole, vert surface mount, straddle, right angle thru hole. 200 pin-- vert surface mount, straddle mount, right angle thru hole.

240 pin-- right angle through hole.

Based on the above I propose the following:

Use of the 160 pin surface mount for the Calliope modules -- this will provide enough extra pins for the low power 5V, -5V, 12V, -12V, etc.

Use the 160 pin for the Euterpe [ according to jay tomlinson, this needs 152 pins]. If this is not enough headroom, then the next step up would be the 200 pins. Opinions ?

This brings us to the last problem, i.e. the mnemo modules. Presently we are talking about using the 80 pin micropax -- is this enough? The next step up would be the 160 pin. Opinions on this ?

```
rich (Rich McCauley)
From:
                      Thursday, January 19, 1995 6:44 PM
Sent:
                      'graham'; 'tbr'
To:
Cc:
                      'pandora'
                     Re: CMOS clocks
Subject:
> From tbr Wed Jan 18 17:16:33 1995
> Date: Wed, 18 Jan 1995 17:16:27 -0800
> From: tbr (Tim B. Robinson)
> To: graham (Graham Y. Mostyn)
> Cc: pandora, rich
> Subject: Re: CMOS clocks
> Content-Length: 740
> Graham Y. Mostyn wrote (on Wed Jan 18):
     I also agree with this approach. I would point out, however, that
Tim's
     suggestion about use of Calliope as a reference clock source is
undesirable,
     since digital-only Pandora systems may not require Calliope to
provide I/O.
     Separate clock arrangements would then have to be made for the CMOS
     Euterpe.
> We are making provision for a separate 54MHz reference when there is
> no Calliope. Hoever, if there is a Calliope, it's essential we can
> run everything from a single reference or the Hermes channels will not
> function. Assumeing we still want the cleanest possible clock to
> Calliope, we must then be able to generate the CMOS euterpe clock from
```

Or, alternatively, we could provide an external divide by circuit which takes as it's input the 1080Mhz clock directly. This may be too restrictive though, because it could only generate 1080/n.

rich

> Tim

> the 54MHz Calliope output.

From: Sent:

craig Thursday, January 19, 1995 6:56 PM 'geert hchu tbe' 'pandora'

To: Cc:

Subject:

Re: Euterpe module form factor

10 cm  $\times$  10 cm sounds like an awfully big die.

Craig

Sent:

craig (Craig Hansen) Thursday, January 19, 1995 7:56 PM 'geert'; 'hchu'; 'tbe'

To:

Cc:

'pandora'

Subject:

Re: Euterpe module form factor

10 cm  $\times$  10 cm sounds like an awfully big die.

Craig

tbr (Tim B. Robinson)

Sent:

Thursday, January 19, 1995 8:38 PM

To: Cc: 'craig (Craig Hansen)' 'dickson'; 'euterpe'

Subject:

Re: Cerberus octlet 6

Craig Hansen wrote (on Thu Jan 19):

On Mnemosyne, and I assume Calliope as well, the part was to stay in reset or clear until the corresponding bit was explicitly cleared (set to zero). Clearly, Euterpe must automatically come out of reset and clear, and in such a case, the Cerberus bits should be cleared by the end of the operation.

Aha, that explains the confusion. I believe it is the case that Mnemosyne and Calliope behave that way, and of course Euterpe comes out autonomously. Now, given we have the bits in octlet 7 which show the actual state of reset completion, is it acceptable to just make the bits in octlet 6 read 0? That's a simple fix I think.

Tim

tbr (Tim B. Robinson)

Sent:

Thursday, January 19, 1995 11:03 PM

To: Cc: 'hchu (Herman Chu)'

Subject:

'geert', 'hchu', 'pandora', 'tbe' Re: Euterpe module form factor

Herman Chu wrote (on Thu Jan 19):

With the reduced power (from 150 watts to 100 watts), relaxed junction temperature requirement and larger die size (I am using  $10 \, \text{cm}$  x  $10 \, \text{cm}$  in my

Hey when did we go to wafer scale integration! Assume a square die of 3sq cm area.

calculations). We can use the same new Eu heat sink design. We might be able to do better with the junction temperature than 127 deg C (I assume we are talking about deg C, not deg F) at the worst environmental conditions.

tbr (Tim B. Robinson)

Sent:

Thursday, January 19, 1995 11:09 PM

To:

'vijay@MicroUnity.com'

Cc:

'dbulfer'; 'noel'; 'pandora'; 'tbe'; 'vijay'

Subject:

Micropax availability

vijay@MicroUnity.com wrote (on Thu Jan 19):

Just found out about the avialabilty of the various positions and flavors on the Micropax connector.

80 pin-- vertical thru hole, vert surface mount, straddle mount.

100 pin-- vertical surface mount

120 pin-- vertical surface mount

160 pin-- vert thru hole, vert surface mount, straddle, right angle thru hole. 200 pin-- vert surface mount, straddle mount, right angle thru hole.

240 pin-- right angle through hole.

Based on the above I propose the following:

Use of the 160 pin surface mount for the Calliope modules -- this will provide enough extra pins for the low power 5V, -5V, 12V, -12V, etc.

Use the 160 pin for the Euterpe [ according to jay tomlinson, this needs 152 pins]. If this is not enough headroom, then the next step up would be the 200 pins. Opinions ?

This brings us to the last problem, i.e. the mnemo modules. Presently we are talking about using the 80 pin micropax-- is this enough ? The next step up would be the 160 pin. Opinions on this ?

We should be trying to make the mnemo and calliope slots as generic as possible to allow for the possibility of different configurations in the future. 80 pins is fine for Mnemosyne, and 160 is fine for Euterpe. 80 would be fine for Calliope except for the requirement for auxilliary supplies. Given that there is no way we can bring the 3.3 in through the same connector, is there a possible solution which combines the auxilliary power with the main 3.3V power rather than with the signal connector? If so we can then keep the signal connector identical between Mnemosyne and Calliope.

Tim

hopper (Mark Hofmann)

Sent:

Friday, January 20, 1995 12:15 AM

To:

'geert (Geert Rosseel)'; 'billz (Bill Zuravleff)'

Subject:

output of euterpe/verilog/bsrc/nb/.checkoutrc (fwd)

Buffalo Chip writes:

From chip Thu Jan 19 23:03:07 1995 Date: Thu, 19 Jan 1995 23:00:22 -0800

From: chip (Buffalo Chip)

Message-Id: <199501200700.XAA15883@tomato.microunity.com>

To: hopper

Subject: output of euterpe/verilog/bsrc/nb/.checkoutrc

The output from euterpe/verilog/bsrc/nb/.checkoutrc is 1952k, so it is not included in this mail message. Instead, check the file

/n/tmp/chiplog/hopper.tomato.15343.euterpe-verilog-bsrc-nb

(which is accessible from all machines). This file will disappear in about 5 days.

By the way, the exit status returned by .checkoutrc was 0.

tbr (Tim B. Robinson)

Sent:

Friday, January 20, 1995 8:14 AM

To:

'tbe (Tom Eich)'

Cc: Subject: 'Graham Y. Mostyn'; 'pandora' Re: Mixed-signal module power

Tom Eich wrote (on Fri Jan 20):

On Thursday, January 19, Graham Mostyn wrote:

- > Tom, I've reviewed Noel's first estimate on the Pandora
- > mixed-signal module power consumption, which is based on the
- > power requirement to Hestia, of 67W (Calliope) + 35W (discretes).

>

- > On account of the limited functionality and simpler design of
- > the modules, they will actually consume much less; we estimate
- > 67W (Calliope) + 4W (discrete) = 71W.

>

Last I heard, Calliope was 54.9W nominal. What is the rationale behind the 67W number? We need steady-state nominal and worst-case numbers for all dissipators for thermal analysis.

As far as I know it is still 54.9. 67 may be a typo, for a long time that was the estimate for Euterpe.

Tim

tbr (Tim B. Robinson)

Sent:

Friday, January 20, 1995 11:03 AM

To:

'brianl'; 'tom'

Cc:

'geert'

Subject:

snapshot make

I died about a half an hour ago:

Deal exiting with status 1

gmake[2]: \*\*\* [do-mlobe-time] Error 1

gmake[2]: Leaving directory

`/N/auspex/root/s23/euterpe-proteus-cp/leafgen'

gmake[1]: \*\*\* [all] Error 1

gmake: \*\*\* [proteusmake] Error 1

Can you check what went wrong please? (The log is in makerrs2).

Tim

brianl (Brian Lee)

Sent:

Friday, January 20, 1995 11:13 AM

To:

'Tim B. Robinson'

Cc:

'tom (Thomas Laidig)'; 'geert (Geert Rosseel)'

Subject:

Re: snapshot make

## Tim B. Robinson writes:

I died about a half an hour ago:

Deal exiting with status 1

gmake[2]: \*\*\* [do-mlobe-time] Error 1

gmake[2]: Leaving directory

/N/auspex/root/s23/euterpe-proteus-cp/leafgen/

|gmake[1]: \*\*\* [all] Error 1 |gmake[1]: Leaving directory

/N/auspex/root/s23/euterpe-proteus-cp/leafgen'

gmake: \*\*\* [proteusmake] Error 1

Can you check what went wrong please? (The log is in makerrs2).

Two lobes failed because of stale NFS file handles for tt2wave. You can restart it and it will re-do those two that failed and then continue.

Brian L.

From: Sent: sysadm@gaea on behalf of Jeff Marr [jeffm@MicroUnity.com]

Friday, January 20, 1995 11:19 AM

To:

'euterpe@gaea'

In article <199501200238.SAA04659@aphrodite.microunity.com>, tbr@gaea.microunity.com (Tim B. Robinson) writes:

> Craig Hansen wrote (on Thu Jan 19):

On Mnemosyne, and I assume Calliope as well, the part was to stay in reset or clear until the corresponding bit was explicitly cleared (set to zero). Clearly, Euterpe must automatically come out of reset and clear, and in such a case, the Cerberus bits should be cleared by the end of the operation.

> Aha, that explains the confusion. I believe it is the case that
> Mnemosyne and Calliope behave that way, and of course Euterpe comes
> out autonomously. Now, given we have the bits in octlet 7 which show
> the actual state of reset completion, is it acceptable to just make
> the bits in octlet 6 read 0? That's a simple fix I think.

> Tim

Is it the intention that a boot program can determine the restart reason entirely from the contents of octlet 7?

I do not see how a program can tell the difference between a normal reset and a program invoked clear. The boot SW needs to know that. I suppose it can surmise from the deferred write bit in octlet 6 that it was a clear.

Am I missing something here?

Jeff Marr

graham (Graham Y. Mostyn) From: Friday, January 20, 1995 11:25 AM Sent: 'tbe'; 'tbr' To: Cc: 'graham@MicroUnity.com'; 'pandora' Re: Mixed-signal module power Subject: Actually I focussed on the board level consumption, and copied the Calliope consumption from Noel's spec, 20A at 3.3V = 66W. My mistake not to verify that too. Nothing has changed on Calliope! Graham. > From tbr Fri Jan 20 06:14:16 1995 > Date: Fri, 20 Jan 1995 06:13:55 -0800 > From: tbr (Tim B. Robinson) > To: the (Tom Eich) > Cc: graham@MicroUnity.com (Graham Y. Mostyn), pandora > Subject: Re: Mixed-signal module power > Content-Length: 779 > Tom Eich wrote (on Fri Jan 20): On Thursday, January 19, Graham Mostyn wrote: > Tom, I've reviewed Noel's first estimate on the Pandora > mixed-signal module power consumption, which is based on the > power requirement to Hestia, of 67W (Calliope) + 35W (discretes).

Last I heard, Calliope was 54.9W nominal. What is the rationale behind the 67W number? We need steady-state nominal and worst-case numbers for all dissipators for thermal analysis.

> On account of the limited functionality and simpler design of > the modules, they will actually consume much less; we estimate

> 67W (Calliope) + 4W (discrete) = 71W.

> As far as I know it is still 54.9. 67 may be a typo, for a long time > that was the estimate for Euterpe.

> Tim

```
'tbe (Tom Eich)'; tbr (Tim B. Robinson)'; 'graham@MicroUnity.com'; 'pandora'
Cc:
                     Re: Mixed-signal module power
Subject:
> Actually I focussed on the board level consumption, and copied the
> Calliope consumption from Noel's spec, 20A at 3.3V = 66W.
> My mistake not to verify that too. Nothing has changed on Calliope!
> Graham.
I would point out that there are changes pending. In particular we are committed to adding
additional atoms for :
      Receiver IQ Balancer
                               (~5000 additional per receiver)
      uP bus interface (TBD)
to the first rev of Calliope. I'd probably add about 2W to the Calliope number.
> > From tbr Fri Jan 20 06:14:16 1995
> > Date: Fri, 20 Jan 1995 06:13:55 -0800
> > From: tbr (Tim B. Robinson)
> > To: tbe (Tom Eich)
 > Cc: graham@MicroUnity.com (Graham Y. Mostyn), pandora
 > Subject: Re: Mixed-signal module power
 > Content-Length: 779
 > Tom Eich wrote (on Fri Jan 20):
> >
       On Thursday, January 19, Graham Mostyn wrote:
> >
       > Tom, I've reviewed Noel's first estimate on the Pandora
 >
>
 >
       > mixed-signal module power consumption, which is based on the
       > power requirement to Hestia, of 67W (Calliope) + 35W (discretes).
>
 >
       > On account of the limited functionality and simpler design of
       > the modules, they will actually consume much less; we estimate
 >
       > 67W (Calliope) + 4W (discrete) = 71W.
> >
> >
> >
       Last I heard, Calliope was 54.9W nominal. What is the rationale
       behind the 67W number? We need steady-state nominal and worst-
> >
       case numbers for all dissipators for thermal analysis.
> >
 > As far as I know it is still 54.9. 67 may be a typo, for a long
   time that was the estimate for Euterpe.
> > Tim
> >
```

Sent: To: agc (Alan Corry)

'Graham Y. Mostyn'

Friday, January 20, 1995 11:37 AM

Gregg Kellogg [gregg@hts.microunity.com]

Sent:

Friday, January 20, 1995 11:47 AM

To:

Subject:

Current failure of terp

Well, now it's once again failing in dlws get next line+1148. It get's a machine check with an illegal instruction. The value of \$pc certainly seems to decode as a valid, legal instruction.

I trust that if you repeat my steps you should see the same behavior. My hands are off this stuff for the time being.

You're best to try running it in ~gregg/stb/apps/tv directly to eliminate any other sources of error (maybe you should even run it as me :-).

Note that handle->curline == 4, indicating that the routine's only been entered a couple of times.

The only thing interesting about this particular place in the code is that we've just started up two calliope event handlers (video-out and audio-out).

Here's the contents of my screen:

```
gregg hts(688):~/stb/apps/tv> /a/soft/stb/bin/tgdb kernel GDB is free software and you are
welcome to distribute copies of it under certain conditions; type "show copying" to see
There is absolutely no warranty for GDB; type "show warranty" for details.
GDB 4.12.86 (mips-sgi-irix5 --target terp-stb), Copyright 1994 Free Software Foundation,
Inc...
Breakpoint 1 at 0x20000000160
Connected to the simulator.
0x200000000160 in last real ()
Breakpoint 2 at 0xfff000000004628: file trap.c, line 231.
Breakpoint 3 at 0xfff000000003704: file task.c, line 627.
[Switching to thread 2 (cylinder 2)]
Breakpoint 3, task switch (task=0xfffffffffffffffff) at task.c:627
            int curcyl = CURRENT CYL;
0xfff0000000008194 in task loader () at taskload.c:90
            task_switch(task);
Breakpoint 4 at 0x80004c: file tv_main.c, line 71.
Breakpoint 5 at 0x812be8
```

[Switching to thread 1 (cylinder 1)] Breakpoint 4, main () at tv main.c:71

tv\_thread\_id = threadCreate(&sched\_params, (void \*)tv\_stack, 71 (gdb) c

Continuing.

```
0.670570 ms(ao=0):NO SIGNAL: wait for message
0.920687 ms(ao=0):ACQUIRE PAT: wait for PAT
0.981548 ms(ao=0):ACQUIRE PAT: new PMT PID 2
1.027178 ms(ao=0):ACQUIRE PMT: wait for video PID
```

1.068048 ms(ao=0):ACQUIRE PMT: new video PID 16 1.115131 ms(ao=0):INIT VIDEO: decode video

Breakpoint 6 at 0x812a1c: file assert.c, line 9.

55.626957 ms(ao=0):INIT VIDEO: Initialize DLWS 56.252281 ms(ao=0):INIT VIDEO: presentation s/e (0.000000/0.000000)

56.322067 ms(ao=0):INIT AUDIO: audio PID 17 56.384594 ms(ao=0):SECOND VIDEO: decode video

78.213699 ms(ao=0):START DLWS: active video start @101.651956 78.373970 ms(ao=0):START

AUDIO: run to acquire at 101.651956

80.050102 ms(ao=96):START AUDIO: enable audio at 110.363067 80.170807 ms(ao=96):AWAIT AUDIO: wait until 93.301841

80.314018 ms(ao=96):DECODE PSI: decode PSI

```
80.417145 ms(ao=96):FRAME SYNC: dlws_next s/e (101.651956/135.018622)
80.514145 ms(ao=96):FRAME SYNC: receiveMessage 93.321320 ms(ao=96):DECODE AUDIO: decode
audio frame
94.919273 ms(ao=192):AWAIT AUDIO: wait until 101.986878 Cylinder 4 got exception 8 while
in interrupt mode.
       pc = 0xfff0800000c047a8
       r00 = 0xfff0800000c02e90
                                       r01 = 0xfff0800000801ff0
       r02 = 0xfff0800000804730
                                       r03 = 0xfff0800000802940
       r04 = 0x0000000000000500
                                      r05 = 0xfff0800000802c00
       r06 = 0x0004b1400005e240
                                      r07 = 0 \times 00004 b1400005 dd40
       r08 = 0 \times 00000000000000000
                                      r09 = 0xfff0800000802ec0
       r11 = 0x0000000000000280
       r12 = 0 \times 00000000000000280
                                       r13 = 0x0000000000000281
       r14 = 0x0000000000000000
                                       r15 = 0x00000000000000001
       r17 = 0x0000000000000000
                                       r19 = 0x0000000000008000
       r18 = 0xfff9002808400000
       r20 = 0x000000000000000004
                                      r21 = 0x0000000000000000
       r22 = 0xfff92000000a4020
                                      r24 = 0xffffffffffffff
                                      r25 = 0xffffffffffffffff
       r26 = 0x0000000000ffffff
                                      r27 = 0x00000000000000007
       r28 = 0x00000000fffffff
                                      r29 = 0xfff92000000a4030
       r30 = 0x00000000000000000fff
                                      r31 = 0x0000000000000000
       r33 = 0x0004b1400005e240
       r34 = 0x0001000001020206
                                       r35 = 0x0202020201010101
                                       r37 = 0xfff0800000802c00
       r38 = 0x0004b1400005ed3e
                                       r39 = 0x000000000000002c0
       r40 = 0x00000000005002c0
                                       r41 = 0x4740474047404740
                                      r43 = 0x0000000000000000
       r42 = 0x0000000000000000
       r44 = 0x0000000000000000
                                      r45 = 0xfff0800000802c00
       r46 = 0xfffffffffffffff
                                      r47 = 0xffffffffffffffffff
       r48 = 0xfff0800000803180
                                      r49 = 0xfff08000008034d0
       r50 = 0x0004b1400005dd40
                                      r51 = 0xfff9002800001160
                                      r53 = 0xfff0800000802940
       r52 = 0x000000000000000000
                                      r55 = 0x8080808080808080
       r54 = 0x8080808080808080
       r56 = 0x0000000000000000
                                      r57 = 0x0000000000000000
       r58 = 0x0000000000000000
                                       r59 = 0x0000000000000000
                                       r61 = 0 \times 0 f 0 f 0 f 0 f 0 f 0 f 0 f
       r60 = 0 \times 0 f 0 f 0 f 0 f 0 f 0 f 0 f 0 f
       r62 = 0x0000000000000000
                                       r63 = 0xfff0800000800880
Machine check
Program received signal SIGILL, Illegal instruction.
[Switching to thread 4 (cylinder 4)]
--- Type <return> to continue, or q <return> to quit---
Program received signal SIGILL, Illegal instruction.
dlws get next line (handle=0xfff0800000804730, buf=0xfff0800000802940)
   at dlwsrt.c:204
204
                           yh = *yptr++;
(gdb) x/i $pc
0xfff0800000c047a8 <dlws get next_line+1148>:
                                               1128li
                                                             r40,r6,0
(gdb) p/x $r6
$1 = 0x4b1400005e240
(gdb) x/i 0xfff0800000c047a8
                                               11281i
0xfff0800000c047a8 <dlws get next line+1148>:
                                                             r40,r6,0
(gdb) p handle->curline
$2 = 4
(gdb)
```

Gregg Kellogg MicroUnity Systems Engineering, Inc. 255 Caspian Drive, Sunnyvale, Ca 94089-1015 gregg@microunity.com

Sent:

hchu (Herman Chu) Friday, January 20, 1995 11:51 AM 'tbr'; 'geert'; 'tbe' 'pandora'

To:

Cc:

Subject:

Re: Euterpe module form factor

The current die size estimate is 3 sq. cm. I meant 2 cm  $\times$ 

2 cm

before and not 10 cm x 10 cm. Sorry.

Thank you.

sysadm@gaea on behalf of Bob Morgan [bobm@MicroUnity.com]

**Sent:** Friday, January 20, 1995 11:55 AM

To:

'euterpe@gaea'

Ηi,

I've released version 1.6 of the Euterpe MicroArchitecture guide. As always, you can type "gmake book" in the doc directory to print out your own copy, or let me know and I'll be happy to print out a bound copy for you. The list of changes in this version are in the back of the book.

If you have any old versions of the book that you want to get rid of, I'd be happy to dispose of them for you. Just let me know.

Also, as always, comments and suggestions are appreciated. Thanks,

Bob

From: Sandeep Nijhawan [sandeep@dolphin]

Sent: Friday, January 20, 1995 12:03 PM

To: 'tbr@doiphin'; 'jeffm@dolphin'

Subject: Cerberus Oct 6

I posted this to muse euterpe yesterday and I assumed it also gets sent to the euterpe mailing list since you folks probably don't read the newsgroups -

>|> It is the act of

> writing to octlet 6 with one of these bots set that actually triggers

> the reset, not the static level of the bit. So would it make more

>> sense if these bits always returned 0 on a read?

>Yes, it seems better to me to make them return always zero.

Hmm... If these bits are always read as zero how do we distinguish reset from logic clear from machine check?

Currently the boot code looks at the reset bit in oct 6 and if it finds it set and the clear bit not set it assumes a power-on reset and so turns up the knobs and then sets the clear bit (while zeroing the reset bit). The second time around it should find just the clear bit set and it simply zeros it and proceeds with the boot sequence. If both bits are zero it assumes a machine check (as per the TSA). It uses the bits in oct 7 just to make sure the reset or logic clear has completed successfully.

I don't see why having to make sure these bits are zero while writing to oct 6 is so bad.

Sandeep

Sent:

Buffalo Chip [chip@rhea] Friday, January 20, 1995 4:41 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/hc BOM 79.0 initiated by woody completed @ Fri Jan 20
14:40:25 PST 1995 with exit status 2.. chip

lisar (Lisa Robinson)

Sent:

Friday, January 20, 1995 8:11 PM

To:

'tbr'; 'geert'

Subject:

splvs

How do I make an lvs netlist?

I tried lysnet and got:

gmake[1]: \*\*\* No rule to make target `euterpe-pass1.splvs'. Stop.
gmake[1]: Leaving directory `/s2/euterpe/verilog/bsrc'

page queued

Lisa R.

tbr (Tim B. Robinson)

Sent:

Friday, January 20, 1995 11:04 PM

To: Cc: 'bobm (Bob Morgan)'

Subject:

'veena'; 'craig' BIST bit

Bob Morgan wrote (on Fri Jan 20):

Hi Tim, Can you tell me where the BIST bit is in mnemo's cerberus registers?

Bit 61 in octlet 6 is defined as "selftest", so I think this is what should be used. Bit's 60:48 are then available to further control the tests. (I'm looking at my euterpe document to get this, but I beleive it is the same int he original Mnemosyne definition, though of course in the first version it was not implemented.)

Now as far as I know, Craig's definition only allocates a single bit in octlet 7 (bit 62) to report the result, whereas the actual design reports much more and the proposal was to report an entire octlet's worth of status. Craig, can you let bob know what preference you have for where to report this?:

| Octlet Bits          | field name       | def.value | range  | interpretation                      |
|----------------------|------------------|-----------|--------|-------------------------------------|
| X 6350<br>bist fail  | fail address     | 0         | 0-3fff | address of last                     |
| 4833 indicator of    | bist test fail   | 0         | 0-ffff | pass=0/fail=1                       |
| indicator of         |                  |           |        | individual bist                     |
| tests(1-16)<br>3128  | comparator fail  | state 0   | 0-f    | comparator fail                     |
| pattern of           | ··· <u>·</u>     |           |        | 7 1. 1 5. 1. 7.                     |
| 1601                 | bist test enable | 0f        | 0-ffff | last bist fail<br>enable bits≈1 for |
| individual           |                  |           |        | bist tests                          |
| (1-16)               |                  |           |        |                                     |
| 00                   | test             | 0         | 0-1    | enables bist                        |
| test(written to zero |                  |           |        |                                     |

tom (Tom Laidig (tau))

Sent:

Saturday, January 21, 1995 12:49 PM

To:

'tbr (Tim B. Robinson)'; 'geert (Geert Rosseel)'; 'vo (Tom Vo)'; 'brianl (Brian Lee)'

Cc:

'cadettes'; 'tom (Thomas Laidig)'

Subject:

new leafmold, etc.

I think everything is ready to build the latest and greatest leaf cell layouts. I've checked in and released:

a new version of vlsimm (including man page) that adds a notch\_fill function for filling now-illegal metal notches and holes. Note that the current implementation is abysmally inefficient, but it works, certainly well enough for the xb cells, and I have some ideas for how to improve it later if/when required.

the new lobe layouts needed to improve the output characteristics of the big or gates

and (as a non-dot-zero version, so it didn't build in /u/chip) the changes to leafmold to make use of all this stuff, and also to save the previous layouts and wire-cap files (in the directories leafgen/leafmold/{layout,wire-cap}-save) to help brianl or whomever analyze why the timing of some gate suddenly changed for no apparent reason

As I understand it, we plan to run this stuff first in the snapshot, then, when we have the cpu cycles available, back-fill it into /u/chip. The above changes will cause a complete rebuild of all leaf cell layouts -- hopefully the last such before we tape out euterpe.

I think I've tested this stuff pretty well in my local area, so I think it'll work (I checked that, as expected, no leaf cells changed size). If anything's needed, send me a page... I'll be out on the bay most of the rest of the day today, but I'll get to it as soon as I can this evening.

<u>'\_\_\_'</u>

tbr (Tim B. Robinson)

Sent:

Saturday, January 21, 1995 12:59 PM

To:

'tom (Tom Laidig (tau))'

Cc:

'brianl (Brian Lee)'; 'cadettes'; 'geert (Geert Rosseel)'; 'tom (Thomas Laidig)'; 'vo (Tom Vo)'

Subject:

new leafmold, etc.

tau wrote (on Sat Jan 21):

I think everything is ready to build the latest and greatest leaf cell layouts. I've checked in and released:

a new version of vlsimm (including man page) that adds a notch\_fill function for filling now-illegal metal notches and holes. Note that the current implementation is abysmally inefficient, but it works, certainly well enough for the xb cells, and I have some ideas for how to improve it later if/when required.

the new lobe layouts needed to improve the output characteristics of the big or gates

and (as a non-dot-zero version, so it didn't build in /u/chip) the changes to leafmold to make use of all this stuff, and also to save the previous layouts and wire-cap files (in the directories leafgen/leafmold/{layout,wire-cap}-save) to help brianl or whomever analyze why the timing of some gate suddenly changed for no apparent reason

As I understand it, we plan to run this stuff first in the snapshot, then, when we have the cpu cycles available, back-fill it into /u/chip. The above changes will cause a complete rebuild of all leaf cell layouts -- hopefully the last such before we tape out euterpe.

I think I've tested this stuff pretty well in my local area, so I think it'll work (I checked that, as expected, no leaf cells changed size). If anything's needed, send me a page... I'll be out on the bay most of the rest of the day today, but I'll get to it as soon as I can this evening.

I'll pick it up now. The last version had died again and I'm waiting for brian's post mortem, but I may as well get the new run started. I did notice a few layout checkins which have not been released. Are these relevant?

tom (Tom Laidig (tau))

Sent:

Saturday, January 21, 1995 1:04 PM

To:

'Tim B. Robinson'

Cc:

'brianl (Brian Lee)'; 'cadettes'; 'geert (Geert Rosseel)'; 'vo (Tom Vo)'; 'tau'

Subject:

Re: new leafmold, etc.

## Tim B. Robinson writes:

tau wrote (on Sat Jan 21):

As I understand it, we plan to run this stuff first in the snapshot, then, when we have the cpu cycles available, back-fill it into /u/chip. The above changes will cause a complete rebuild of all leaf cell layouts -- hopefully the last such before we tape out euterpe.

I think I've tested this stuff pretty well in my local area, so I think

it'll work (I checked that, as expected, no leaf cells changed size). If anything's needed, send me a page... I'll be out on the bay most of the rest of the day today, but I'll get to it as soon as I can this evening.

I'll pick it up now. The last version had died again and I'm waiting for brian's post mortem, but I may as well get the new run started. I did notice a few layout checkins which have not been released. Are these relevant?

Sounds good. Any unreleased layout checkins should be irrelevant.

'<u>\</u>

Sent:

tbr (Tim B. Robinson) Saturday, January 21, 1995 10:24 PM 'stick'; 'bpw' 'geert'; 'tom'

To: Cc:

Subject:

ged/ca BOM

In updating the proteus snapshot for euterpe I notice we do not have a .0 BOM in proteus/ged/ca. Should there be a release there?

tbr (Tim B. Robinson)

Sent:

Sunday, January 22, 1995 12:06 AM

To: Cc: 'craig (Craig Hansen)'

Subject:

'euterpe'; 'mws'
Re: EUTERPE WORKING: SMux64 not to be supported

Craig Hansen wrote (on Mon Jan 16):

smux is also useful for writing a subset of the bits of an octlet, as may occur in modifying a bit field in a structure. smux also permits (but obviously does not require) a much faster implementation, as it doesn't modify reg state and can therefore be performed with timing of stores; i.e. it can be bufferred.

It seems foolish to me to nuke the instruction just to avoid fixing a bug.

It would be nice to fix it, I agree, but mark thinks the fix is non-trivial and since the software group have said they don't need it we have it at the bottom of the priority list at present.

Curtis Abbott [abbott@MicroUnity.com] Sunday, January 22, 1995 12:34 AM

Sent: To:

'tbr@MicroUnity.com'

Cc:

Craig Hansen; 'euterpe@MicroUnity.com'; 'mws@MicroUnity.com'

Subject:

Re: EUTERPE WORKING: SMux64 not to be supported

Tim Robinson wrote (on Sat Jan 21):

Craig Hansen wrote (on Mon Jan 16):

smux is also useful for writing a subset of the bits of an octlet, as may occur in modifying a bit field in a structure. smux also permits (but obviously does not require) a much faster implementation, as it doesn't modify reg state and can therefore be performed with timing of stores; i.e. it can be bufferred.

It seems foolish to me to nuke the instruction just to avoid fixing a bug.

It would be nice to fix it, I agree, but mark thinks the fix is non-trivial and since the software group have said they don't need it we have it at the bottom of the priority list at present.

Perhaps I should say why software says they don't need it...

smux is a subset of smas -- both write a subset of the bits of an octlet, smas also writes a destination register while smux doesn't. So smas handles our needs -- it's easy enough to ignore the result in the register. As to the faster implementation, mark isn't taking it out of the architecture, just out of this implementation, where it wouldn't have been faster anyway.

- Curtis

tbr (Tim B. Robinson)

Sent:

Sunday, January 22, 1995 12:11 PM

To:

'fwo'

Cc:

'dickson'; 'geert'

Subject:

csyn run

I made an splvs netlist from BOM 205.0 for lisar to convert to edif for logic verification. However, I decided to run csyn since I had it. Ther result is in ~tbr/euterpe/verilog/bsrc/euterpe-pass1.csyn (I used the 'lvsnet' target to get this). I was rather surprised to see > 2MB of output. Canyou take a look please?

tbr (Tim B. Robinson)

Sent:

Sunday, January 22, 1995 1:00 PM

To:

'lisar (Lisa Robinson)'

Cc: Subject: 'geert'

splvs

Lisa Robinson wrote (on Fri Jan 20):

How do I make an lvs netlist?

I tried lysnet and got:

gmake[1]: \*\*\* No rule to make target `euterpe-pass1.splvs'. Stop.

gmake[1]: Leaving directory \s2/euterpe/verilog/bsrc'

page queued

I checked in a Makefile change and was able to build it with the 'lvsnet' target. The change was just to make the v2e step use the beavioral gtlb and register file to speed up the compilation.

After making sure I had made ckgards in the ck section I ran

gmake GARDS\_SUBDIRS\_1=ck GARDS\_SUBDIRS\_2= lvsnet

fwo (Fred Obermeier)

Sent:

Monday, January 23, 1995 3:00 AM

To:

'tbr'

Cc:

'dickson'; 'fwo'; 'geert'

Subject:

Re: csyn run

Tim,

The current released version of csyn and its rules is out of date.

I haven't done a releasebom yet since the differential input swing check tests is not 100% correct yet. However, I have made other fixes to things like Exclusive input swing checks. The original test cases provided to me for the exclusive input swing checks was not right.

Therefore, neither are the released set of rules. I still don't think the exclusive checks are right yet.

Most of the errors in your csyn run refer to a fix I made to properly handle logic0\_ab0pf. This gets mapped into logic1\_abnd0pf.

I have fixed the logic0/logic1 errors in my local copy too.

Looks like your splvs deck also has quite a few floating inputs.

These inputs also cause ADRS errors. The output shorts may be real problems.

Do you think I should release my incomplete but better version of csyn/celltest?

My csyn runs looks a bit better:

~/chip.bsrc/euterpe/verilog/bsrc/tbr\_euterpe-pass1.csyn

Fred.

tbr (Tim B. Robinson)

Sent:

Monday, January 23, 1995 10:45 AM

To: Cc: 'fwo (Fred Obermeier)' 'dickson'; 'fwo'; 'geert'

Subject:

Re: csyn run

Fred Obermeier wrote (on Mon Jan 23):

Tim,

The current released version of csyn and its rules is out of date. I haven't done a releasebom yet since the differential input swing check tests is not 100% correct yet. However, I have made other fixes to things like Exclusive input swing checks. The original test cases provided to me for the exclusive input swing checks was not right. Therefore, neither are the released set of rules. I still don't think the exclusive checks are right yet.

Most of the errors in your csyn run refer to a fix I made to properly handle logic0\_ab0pf. This gets mapped into logic1\_abnd0pf. I have fixed the logic0/logic1 errors in my local copy too. Looks like your splvs deck also has quite a few floating inputs. These inputs also cause ADRS errors. The output shorts may be real problems.

Do you think I should release my incomplete but better version of csyn/celltest?

I think it would be worthe a release, otherwise someone may waste some time on propblems you have already fixed.

My csyn runs looks a bit better:
 ~/chip.bsrc/euterpe/verilog/bsrc/tbr\_euterpe-pass1.csyn

Thanks. I'll leave you to interpret the results as you have been doing and to post the analysis.

wampler (Kurt Wampler)

Sent:

Monday, January 23, 1995 11:07 AM

To:

'geert'

Subject:

Re: Euterpe

> Did you get my latest version ? Can you let me know .. I am ready to >build the next one ..

Yes, I did pick it up yesterday after I got your page. I ran a linesearch route last night, and it did get better in several places. I'm going to investigate in more detail today, particularly the left corridor.

Go ahead and build the next one.

- Kurt

```
From:
```

stick (Bruce Bateman)

Sent:

Monday, January 23, 1995 11:30 AM

To: Cc: Subject: 'bpw'; 'tbr' 'geert'; 'tom' Re: ged/ca BOM

```
> Date: Sat, 21 Jan 1995 20:23:31 -0800
> From: tbr (Tim B. Robinson)
> To: stick, bpw
> cc: geert, tom
> Subject: ged/ca BOM
>
> In updating the proteus snapshot for euterpe I notice we do not have a
> .0 BOM in proteus/ged/ca. Should there be a release there?
> Tim
```

I thought we'd done a release there quite some time ago. I see not reason not to go ahead and do one if you need it. Any schematic activity there is long ago completed.

BB

```
'stick (Bruce Bateman)'
To:
                     'bpw'; 'geert'; 'tom'
Cc:
                    Re: ged/ca BOM
Subject:
Bruce Bateman wrote (on Mon Jan 23):
   > Date: Sat, 21 Jan 1995 20:23:31 -0800
   > From: tbr (Tim B. Robinson)
   > To: stick, bpw
   > cc: geert, tom
   > Subject: ged/ca BOM
   > In updating the proteus snapshot for euterpe I notice we do not have a
   > .0 BOM in proteus/ged/ca. Should there be a release there?
   > Tim
   >
   I thought we'd done a release there quite some time ago. I see
   not reason not to go ahead and do one if you need it. Any
   schematic activity there is long ago completed.
Here's the log of things not released at the ca level:
revision 10.8
date: 1994/11/08 16:23:07 LT; author: bpw; state: Exp; lines: +2 -2 Release Target:
proteus/ged/ca/cawrpre4
Added mbypre_ layout_equiv
revision 10.7
date: 1994/11/08 16:21:36 LT; author: bpw; state: Exp; lines: +2 -2 Release Target:
proteus/ged/ca/cawrpre2
Added mbypre_ layout_equiv
revision 10.6
date: 1994/11/02 15:24:38 LT; author: bpw; state: Exp; lines: +2 -2 Release Target:
proteus/ged/ca/caxldrv
Added layout equiv
revision 10.5
date: 1994/11/02 15:23:15 LT; author: bpw; state: Exp; lines: +2 -2 Release Target:
proteus/ged/ca/cainvbv3
Added layout equiv
revision 10.4
date: 1994/11/02 15:21:51 LT; author: bpw; state: Exp; lines: +2 -2 Release Target:
proteus/ged/ca/cabicx4
Added layout_equiv
revision 10.3
date: 1994/10/31 16:22:49 LT; author: bpw; state: Exp; lines: +2 -2 Release Target:
proteus/ged/ca/cainvbv4
Added cainvbv4t layout_equiv.
```

tbr (Tim B. Robinson)

Monday, January 23, 1995 11:41 AM

From:

Sent:

revision 10.2
date: 1994/10/27 14:26:43 LT; author: stick; state: Exp; lines: +2 -2 Release Target: proteus/ged/ca/cainvbv5

Added parasitic=true to caps, verilog= & layout\_equiv= to sheets.

revision 10.1
date: 1994/10/27 14:25:17 LT; author: stick; state: Exp; lines: +2 -2 Release Target: proteus/ged/ca/cainvbv4

Added parasitic=true to caps, verilog= & layout\_equiv= to sheets.

l
I'll go ahead and release it.

wampler (Kurt Wampler)

Sent:

Monday, January 23, 1995 7:01 PM

To: Subject: 'geert' netcap file

Ηi,

My linesearch result reached this state of completion:

PERCENTAGE OF CONNECTIONS NOW COMPLETE = 98.29% TOTAL CONNECTIONS LEFT UNROUTED = 4585

I've produced a netcap file for this result; it can be found in:

/n/rhodan/s2/wampler/euroute/geert\_euterpe-iter.netcap

also, the file "unconnected.net" in the same directory is the list of all nets that were incompletely routed at the end of linesearch routing.

I'll fire up a maze routing pass tonight.

- Kurt

wayne (Wayne Freitas)

Sent:

Monday, January 23, 1995 8:29 PM 'tbr'; 'lisar'; 'graham'; 'jt'; 'mudge'; 'doi'

To: Cc:

'hestia'; 'wayne'

Subject:

HW Bring-up meeting minutes

Attendees: tbr, doi, jr, graham, lisar, rmm, bill, arya, tbe, philip

Reviewed main board testing status:

- -RF section, Arya and Rick have checked out the input of the RF section upto the LNA's. There was an Isolation problem on one of the relays which is probably due to the PCB layout. This will be looked at in the coming week, along with the Baluns, and filters.
- -Power section, -Sense input on DC-DC Module was shorted to 3.3V plane so that when the shorting resistors were installed there was a 1 ohm path to ground. In addition, further tests need to be performed to find out why there was ~30 deg thermal delta with only 3.5amps on the 3.3V near the DC-DC Module and a ~50 deg delta at a certain via close to Euterpe.

  Noel has not been able to perform any power subsystem tests due to his work on Pandora. Wayne to talk with Noel to see if someone can perform limited amount of tests for him until he's available.

  There was also a problem with the 12V input on the VCO shorting to the ground plane (this provided us with our first smoking Hestia). Problem was caused by solder wicking under the component and shorting to the 12V input lead. Rick and Thuydo have indicated they will look into this.
- Bill express concern on getting some noise measurements caused the SDRAM's Graham, Bill, Yves, Arya and Rick to get together to review tests requirements. Wayne to set-up test jig and perform testing after data is provided.
- Mechanical, mechanical test still in process, 3ea. boxes are available for noise and isolation tests. After mechanical tests are complete JR and Kien to tweak boxes and provide custom shielding for engineers when needed.
- Philip and JR to generate procedures for getting tkgnats bugs incorporated into rework instructions (engineering eco) for in-house use after Wayne provides input.
- -We postponed until next week going over the Calliope and Euterpe delivery dates and additional tests needing to be performed because I haven't updated the schedule to reflect the new delivery dates.

Thats it folks,

Sent:

billz (Bill Zuravleff) Tuesday, January 24, 1995 11:02 AM

To:

'fwo'; 'hardheads'

Subject:

Re: More euterpe csyn reports.

The cc errors -- cc\_hz2or4backr16 and cc\_startr16 being unconnected -- have been fixed and checked in. I'll release when I've got an updated placement. (All these messages from 2 missconnects? These two are the only bugs I fixed.)

Thanks, billz

From: Sent: Tom Eich [tbe@MicroUnity.com] Tuesday, January 24, 1995 1:10 PM

To:

'boxers@MicroUnity.com'; 'dbulfer@MicroUnity.com'

Cc: 'pandora@MicroUnity.com'

Subject:

Pandora open actions, can we close??

On 1/12, the (Tom Eich) wrote:

Actions and status are as follows:

>1) Noel to prepare a power spreadsheet with current by voltage per module or >lowest separable unit.

Status: in progress.

Can this be completed, please? The copy I have still has no fan load accounted for, and also has the incorrect Calliope module power (102W) that Graham corrected.

>snip<

Action: Philip and Noel to prepare power supply trade matrix.

Done, I think. Philip and Noel, are you satisfied?

Action: Noel to survey vendors and id candidate supplies.

What is the status, please?

>snip<

>4) Noel and Vijay to id all signal and signal ground I/O lines for both the >Euterpe and Mnemo bricks >snip<

Status: in progress; signal and signal ground requirements identified.

Has an interconnect list or table been prepared? In another message, Jay Tomlinson requested p/ns for the connectors, has this been done?

Action: Determine power requirements (ref. 1) above) and candidate power connectors and bus bars.

What is the status? I am using the Elcon power connector for now, but believe there is an open question on Calliope module power I/O.

>5) Noel to identify de-coupling cap requirements and the to include in area > calculations and layouts.

Action: in progress.

Can you please close this, Noel?

>snip<

>8) Herman to trade-off integral Mnemo fan vs. external system blower(s); the >and jt to support with layout concepts.

Decision taken to pursue system level blowers for Mnemo modules and PCI cards as a first course, due to noise, size and power impact of individual module fans.

Open action on material/finish for Mnemo heat sink. Can Herman, Vijay and the meet tomorrow at 2:00 to complete action?

>snip<

Action: Noel and David to determine location and type of thermal protection in Pandora.

## Status?

Discussed the PCI card containing the Mnemo and external Hermes port (for hestia, etc). If this card conforms to the PCI mechanical standard, then this Mnemo will need a different heat sink than planned for the modules. Herman

said this was possible, but needed to be assessed.

Action: David raised concern relative to 3.3Vdc input if this is standard PCI card that could go in any slot. How to resolve?

Action: Herman to determine feasibility of low profile heat sink and required flow rate.

Let's discuss at the 2:00 tomorrow, Herman.

## >snip<

Please respond via E-mail to the newsgroup to provide status and close these out.

-Tom

Tom Eich
MicroUnity Systems Engineering, Inc.
255 Caspian Dr. Sunnyvale, CA 94089
(408)734-8100, (408)734-8136 fax

tbe@microunity.com

wampler (Kurt Wampler)

Sent:

Tuesday, January 24, 1995 2:07 PM

To:

'geert'

Subject:

Maze routing result

Нi,

The maze routing pass just finished. Incompletely routed nets went from 4,066 down to 1,832. The "netcap" file for this is:

/n/rhodan/s2/wampler/euroute/geert\_euterpe-iter.maze.netcap

and the list of unconnected nets is in:

/n/rhodan/s2/wampler/euroute/unconnected.maze.net

- Kurt

doi (Derek Iverson)

Sent:

Tuesday, January 24, 1995 2:13 PM

To:

'tbr'

Subject: vitree differences (use a very wide screen)

> /n/auspex/s15/tbr/euterpe/proteus/verilog/clib/dffnq.v

/n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xbffdf8s.v | /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xbffdf6s.v /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff4df12s.v | /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff4df8s.v /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff5df8s.v | /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff5df6s.v /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff6df8s.v | /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff6df6s.v

> /n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborff7df6s.v

/n/auspex/s15/tbr/euterpe/proteus/verilog/dxlib/xborffb7df8s.v

vltree differences (use a very wide screen)

<sup>&</sup>gt; /n/auspex/s15/tbr/euterpe/proteus/verilog/clib/dlatchq.v

mws (Mark Semmelmeyer)

Sent:

Tuesday, January 24, 1995 2:26 PM

To:

'jeffm'; 'djc'

Cc:

'mws'

Subject:

Re: Ifetch Page size

- > From djc Tue Jan 24 09:50:35 1995
- > When I talked to mws about the page size a couple weeks ago, I came
- > away with the impression that even though all values were not
- > supported, they

all

> mapped to legal values. Is this correct?

I think what I wanted to say was that all values greater than the minimum page size would be remapped silently by the hardware to the largest avail size not greater than the programmed size. I wanted to discourage use of sizes that would require remapping upward (sizes less than 64 bytes). It may actually be true that the hardware will do this remapping, but I thought it was a risk for future implementations and would be bad to count on. Going with this, the 18jan95 revision of the euterpe microarch doc in the cerb reg section requires the N programmed to be at least 6.

From: Sent:

Gregg Kellogg [gregg@hts.microunity.com] Tuesday, January 24, 1995 3:08 PM

To:

'Brendan Eich'

Subject:

Re: gnu-tools/sim/terp cycles.c

apps/tv does use cycle-counting, it just doesn't programatically enable/disable it.

Lisa has a reproducable test-case for the tv problem and has been working on it for the last few days. The symptom seems to be that a register value gets changed in midexecution.

By the way, any thought on the tv-app failures (stable and current) relating to continuity-counter botches in mpeg2-in? I didn't notice these yesterday.

Gregg Kellogg MicroUnity Systems Engineering, Inc. 255 Caspian Drive, Sunnyvale, Ca 94089-1015 gregg@microunity.com

fwo (Fred Obermeier)

Sent:

Tuesday, January 24, 1995 3:19 PM

To:

'geert'; 'ong'; 'wingard'

Cc:

'fwo'

Subject:

vy differential drivers?

Drew,

What should I do about the csyn errors relating to shorted differential drivers in eamemalr1wp6x1a? Do we want to allow this? The conversions I had with my model user, Drew, indicated that such a case should not occur. I've included Warren in this e-mail since I think that this is in one of his blocks.

If a csyn rule restricts the drivers to the same instance (\*/), then the new instance checking code for Differential Input Swing checks will flag this as an error since it makes sure that one positive side matches every negative driver, and one of the negative drivers matches every positive driver.

I've saved the last csyn results in
/u/fwo/chip.bsrc/euterpe/verilog/bsrc/OLD1
so that I can check the next BOM. Csyn reports
 DiffInputSwingCheck: drivers come from different insts.
Differential outputs from several instances are shorted together.
The vy qualifier delcaring rbl\_abd0p85vy and rbl\_abnd0p85vy as common emitter and collector outputs should allow these nets to have multiple drivers. The inputs are d0
 \_ad0p85vy and d0\_and0p85vy.

I'd like for Geert or Drew to confirm that either:

- 1. we need a new kind of checking for vy drivers, or
- 2. change the way we check same instance drivers in general, or
- 3. that we should not allow this kind of connection and euterpe should change.

What should I do?

Thanks, Fred.

agc (Alan Corry)

Sent:

Tuesday, January 24, 1995 3:20 PM

To:

'David Bulfer'

Cc:

'graham@MicroUnity.com'; 'tbe (Tom Eich)'; 'hchu (Herman Chu)'; 'pandora'

Subject:

Re: Mixed-signal module power

I would recommend that we at least use the 55W+2W number as the nominal power. The extra 2W represents packing some of the existing design tighter to make room for extra functionality after that there's no more atoms on the chip.

To add to the uncertainty it is known that Calliope's logic family wasn't as well characterized as Euterpe's so its likely that we'll need to turnup the knobs for some domains (if not all domains). So we'd better be prepared for that since unlike Euterpe, we need to meet the design goal of 1296MHz for the digital receivers' filters to operate correctly.

vijay@MicroUnity.com

Sent:

Tuesday, January 24, 1995 3:24 PM

To:

'Tom Eich'

Cc:

'pandora@MicroUnity.com'

Subject:

Re: Pandora open actions, can we close??

```
>On 1/12, tbe (Tom Eich) wrote:
> >snip<
>
> >4) Noel and Vijay to id all signal and signal ground I/O lines for
> >both
the
> >Euterpe and Mnemo bricks >snip<
>
> Status: in progress; signal and signal ground requirements identified.
> Has an interconnect list or table been prepared?
```

Done. Will share at next meeting.

>In another message, Jay Tomlinson requested p/ns for the connectors, >has this been done?

No. We are still discussing whether or not surface mount connectors are necessary.

- > Action: Determine power requirements (ref. 1) above) and candidate
  > power connectors and bus bars.
- >What is the status? I am using the Elcon power connector for now, but >believe there is an open question on Calliope module power I/O.

The non availabilty of extra low power pins on the 80 pin micropax has us looking for other solutions. Two options currently pursuing are the Metral connector from Berg for the all the power voltages. The other option is a multipin connector from Elcon. As soon as we receive enough details on this a decision can be made.

'dbulfer@MicroUnity.com'; 'agc' To: 'graham@MicroUnity.com'; 'tbe'; 'hchu'; 'pandora' Cc: Re: Mixed-signal module power Subject: > From agc Tue Jan 24 13:19:47 1995 > From: agc (Alan Corry) > Subject: Re: Mixed-signal module power > To: dbulfer@MicroUnity.com (David Bulfer) > Date: Tue, 24 Jan 95 13:19:35 PST > Cc: graham@MicroUnity.com, tbe (Tom Eich), hchu (Herman Chu), pandora > X-Mailer: ELM [version 2.3 PL11] > Content-Length: 1400 > > No - in previous mail, I confirmed that the figure for Calliope is indeed > > still ~ 55W. The 67W was an error. > > (Alan Corry has also pointed out that known metal changes on the next >>> revision of Calliope will add to consumption by ~2 watts; however, since >>> there are several unknowns in the next rev., I believe we should continue > > > to budget dissipation for this rev. only, using the ~55W figure) > > Graham. > > > > > My guess is that 2 W is in the noise compared to 55W and all the > > unknowns. But you bring up an interresting issue regarding future > > versions. Is it possible for you to bound power consumption for > > versions that might appear within the next couple of years? It may > > help prevent re-engineering the system when Calliope II emerges. > David > I would recommend that we at least use the 55W+2W number as the > nominal power. The extra 2W represents packing some of the existing > design tighter > to make room for extra functionality after that there's no more atoms > on the > chip. > To add to the uncertainty it is known that Calliope's logic family > as well characterized as Euterpe's so its likely that we'll need to turnup > the knobs for some domains (if not all domains). So we'd better be prepared > for that since unlike Euterpe, we need to meet the design goal of 1296MHz > for the digital receivers' filters to operate correctly.

noel (Noel Verbiest)

Tuesday, January 24, 1995 4:56 PM

From:

Sent:

Any idea how much power is involved in turning up the knobs ? Your best guess will do. Thank you.
Noel. x783

From: jeffm (Jeff Marr)

Sent: Tuesday, January 24, 1995 5:43 PM

To: 'lisar'; 'tbr'

Subject: snoopy and ikos

I have made the changes necessary to support snoopy on the ikos.

This includes building snoop.o in iblib, as well as providing a snoop.vhdl. Also, I have locally made the changes to i\_euterpe\_wrap.tb i\_euterpe\_wrap.vhdl and euterpe\_wrap.V

I would really, really like the various wrapper files to be checked over before I check them in. They are in ~jeffm/bsim/.

Thanx,

jeffm

graham (Graham Y. Mostyn)

Sent:

Tuesday, January 24, 1995 6:49 PM

To:

'hestia'

Cc:

'graham'

Subject:

Hestia main PC board/noise analysis

This note summarizes a meeting held this morning re: investigation of potential analog/digital interaction on the main Hestia board.

While the board layout was carefully designed to avoid this problem, we wished to confirm that conducted and radiated noise from traces carrying high current switching waveforms was minimized, and prevented from entering the RF signal path.

Attendees: arya, bill, graham, rmm, yves

We concluded that the analysis should be done in two parts:

- (1) Obtain an understanding of noise levels and mechanism of conduction, as follows:
- (a) Obtain an unpopulated board, with any undesired shorted vias removed.
- (b) Connect a pulse generator to the Euterpe Vcc/GND at the power supply, and measure induced voltages on Calliope Vcc/GND as a function of frequency.
- (c) Load decoupling capacitors on the board. Repeat (b).
- (d) Investigate the effect of adding shields to the board, and/or board installation within the (shielding) STB case; repeat (b).
- (e) If the induced voltages are very small (we hope so!), increase switching currents by driving a CMOS power device, drawing current via the DRAM power pads, and repeat measurements.
- (f) Load all the components in the RF input circuit, and also measure the induced voltage at the F connector and at the differential input to Calliope. [The requirement here is <luV in a 6MHz bandwidth].
- (2) Verification of results, on a larger sample of units: Perform test (f) only, and collate statistics on measured noise.

Action items: All attendees, coordinating with Wayne.

noel (Noel Verbiest) From: Tuesday, January 24, 1995 7:45 PM Sent: 'boxers'; 'dbulfer'; 'tbe@MicroUnity.com' To: Cc: 'pandora' Re: Pandora open actions, can we close?? Subject: > From tbe@MicroUnity.com Tue Jan 24 11:10:01 1995 > Date: Tue, 24 Jan 95 11:09:54 PST > X-Sender: tbe@gaea.microunity.com > Mime-Version: 1.0 > Content-Type> : > text/plain> ; > charset="us-ascii"> > To: boxers, dbulfer > From: tbe@MicroUnity.com (Tom Eich) > Subject: Pandora open actions, can we close?? > Cc: pandora > Content-Length: 2749 > On 1/12, the (Tom Eich) wrote: Actions and status are as follows: >1) Noel to prepare a power spreadsheet with current by voltage per module > or >lowest separable unit. Status: in progress. > Can this be completed, please? The copy I have still has no fan load > accounted for, and also has the incorrect Calliope module power (102W) that > Graham corrected. Graham will release a new power estimation on the Calliope modules shortly. Will put the new numbers in as soon as I have them. >snip< Action: Philip and Noel to prepare power supply trade matrix. > Done, I think. Philip and Noel, are you satisfied? Action: Noel to survey vendors and id candidate supplies. > What is the status, please?

So far the search for an off-the-shelf unit with own cooling has been pretty inconclusive and it is probably time for us to reexamine our approach. Off-the-shelves singles do not have the mix of output voltages/currents, or they don't have power factor correction, or the vendors are not responsive because of the low volumes. The ones that respond quote leadtimes of 3 to 6 months (semi custom solutions). If we tackle the problem from another angle, and are willing to give up the internal cooling, and are willing to accept multiple packages then a number of off-the-shelf solutions are instantly available to us. Are we willing to consider this?

>snip<

```
>4) Noel and Vijay to id all signal and signal ground I/O lines for
both the
   >Euterpe and Mnemo bricks >snip<
   Status: in progress; signal and signal ground requirements identified.
> Has an interconnect list or table been prepared?
> In another message, Jay Tomlinson requested p/ns for the connectors, has
> this been done?
   Action: Determine power requirements (ref. 1) above) and candidate
power
   connectors and bus bars.
> What is the status? I am using the Elcon power connector for now, but
> believe there is an open question on Calliope module power I/O.
  >5) Noel to identify de-coupling cap requirements and the to include in
area
  >calculations and layouts.
>
  Action: in progress.
> Can you please close this, Noel?
> >snip<
The filtering will be heavily influenced by the choice of the power
supplies. If we need to apply heavy duty filtering, we can fit the
components inside a rectangular space measuring \tilde{\mathbf{1}}" x \mathbf{1}" x 1.5" for the
Euterpe and the Caliope Bricks. Somewhat smaller for the Mnemo's (1" x
1" x 1"). These spaces should be at the power entry points.
> >8) Herman to trade-off integral Mnemo fan vs. external system
blower(s); tbe
   >and jt to support with layout concepts.
> Decision taken to pursue system level blowers for Mnemo modules and PCI
> as a first course, due to noise, size and power impact of individual
module
  fans.
> Open action on material/finish for Mnemo heat sink. Can Herman, Vijay
> tbe meet tomorrow at 2:00 to complete action?
> >snip<
  Action: Noel and David to determine location and type of thermal
protection in
  Pandora.
> Status?
No decisions taken yet. Still being debated.
> Discussed the PCI card containing the Mnemo and external Hermes port
(for
 \cdot hestia, etc). If this card conforms to the PCI mechanical standard,
then this
> Mnemo will need a different heat sink than planned for the modules.
```

```
Herman
  said this was possible, but needed to be assessed.
  Action: David raised concern relative to 3.3Vdc input if this is
standard PCI
  card that could go in any slot. How to resolve?
  Action: Herman to determine feasibility of low profile heat sink and
required
  flow rate.
> Let's discuss at the 2:00 tomorrow, Herman.
> >snip<
> Please respond via E-mail to the newsgroup to provide status and close
> these out.
> -Tom
> Tom Eich
tbe@microunity.com
> MicroUnity Systems Engineering, Inc.
> 255 Caspian Dr. Sunnyvale, CA 94089
> (408)734-8100, (408)734-8136 fax
```

From: Sent: Gregg Kellogg [gregg@hts.microunity.com] Tuesday, January 24, 1995 9:41 PM

o: 'Brendan Eich'

To: Subject:

Re: gnu-tools/sim/terp cycles.c

> Where do you see cc botches? I don't see any when running apps/bench > or kernel.reg (the second-to-top version; fambro removed some mpeg2-in testing

- > for some reason). I'll run apps/tv later tonight. If the cc botches didn't
- > happen yesterday, and mpeg2-in hasn't changed, what has changed?

Like I said, I didn't notice it later, but it happened in last night's regression runs of tw.reg (both stable and current) and happens now if you try to run it. The messages are definitely from mpeg2-in. Perhaps it's something to do with binding to more than one PID?

Gregg Kellogg MicroUnity Systems Engineering, Inc. 255 Caspian Drive, Sunnyvale, Ca 94089-1015 gregg@microunity.com

mws (Mark Semmelmeyer)

Sent: To: Tuesday, January 24, 1995 10:18 PM 'billz'; 'dickson'; 'geert'; 'lisar'; 'woody'

Subject:

euterpe.V 6.348

I checked in euterpe.V 6.348 and some uu stuff which is corequisite with an AT change. This is to fix the UUvldNoXcR11 timing problme.

The AT half of the change is delayed some. I recommend you not check out the uu stuff (it is not BOM'ed) and if you have to modify euterpe.V, modify 6.347 instead and then relabel it

6.348 in your CVS/Entries file to skip the 6.348 version. Hopefully this window of danger will pass soon.

From: woody (Jay Tomlinson)

Sent: Wednesday, January 25, 1995 12:55 AM

To: 'mws (Mark Semmelmeyer)'

Cc: 'billz'; 'tbr'; 'dickson'; 'geert'; 'lisar'

Subject: euterpe.V 6.348

# Mark Semmelmeyer wrote (on Tue Jan 24):

I checked in euterpe.V 6.348 and some uu stuff which is corequisite with an AT change. This is to fix the UUvldNoXcR11 timing problme. The AT half of the change is delayed some. I recommend you not check out the uu stuff (it is not BOM'ed) and if you have to modify euterpe.V, modify 6.347 instead and then relabel it 6.348 in your CVS/Entries file to skip the 6.348 version. Hopefully this window of danger will pass soon.

eutepe.V 6.349 has been checked in along with the at changes that are necessary. 5woody fabbed, dcacheeasy went to bad. I will investigate further.

Jay

Gregg Kellogg [gregg@hts.microunity.com] Wednesday, January 25, 1995 1:08 PM

Sent: To:

'Lisa Repka'

Cc:

'gmo@calliope'; 'fur'; 'brendan'; 'jsw'; 'guarino'

Subject:

Re: simulator finally fixed

On Jan 25, 11:00am, Lisa Repka wrote:

> Subject: simulator finally fixed

- > The changes I just checked-in should make tv work now. I put a terp
- > and a tgdb in ~lisa/bin/sgi5 for you to use until good ones are built
- > and installed.

>

> lisa

>-- End of excerpt from Lisa Repka

Thanks very much for getting this fixed! I'm checking it out right now.

Gregg Kellogg

MicroUnity Systems Engineering, Inc.

255 Caspian Drive, Sunnyvale, Ca 94089-1015 gregg@microunity.com

Sent:

Buffalo Chip [chip@rhea] Wednesday, January 25, 1995 7:12 PM 'geert@rhea'

To:

Subject:

pager log message

page from chip to geert:
Release euterpe/verilog/bsrc/at BOM 43.0 initiated by brianl completed @ Wed Jan 25
17:07:31 PST 1995 with exit status 0.. chip

Wednesday, January 25, 1995 8:02 PM 'solo@hera.microunity.com'; 'brianl' To: Cc: 'geert' Re: clock load Subject: > From brianl Wed Jan 25 17:11:15 1995 > From: brianl (Brian Lee) > Subject: Re: clock load > To: solo@hera.microunity.com (John Campbell) > Date: Wed, 25 Jan 95 17:11:10 PST > Cc: bill (William Herndon), geert (Geert Rosseel) > X-Mailer: ELM [version 2.3 PL11] > Content-Length: 811 > John Campbell writes: what's the recommended clock loading these days. i am doing a custom block for test and don't have a clue. i am driving mostly scsynchll flipflops which have a heavy load like 1.8mA of isrc on the clocks. is there a file i should be looking at. > Hmmmm. If I understand the question correctly, then I'm not sure that
> I know the answer. For normal signals, we tell topt to limit the dc
> load current to 10% of the driving output current. 25% if it's an > emitter follower output. I don't know if clocks have different > constraints. Is this what you were looking for? Will someone else > help out here? > BTW, the latest capacitance and current numbers that were simulated > for the sofa custom cells are in /u/chip/proteus/custom/{caps,dcload}/<cell>.{cap,cur} > > > Brian L. clock is simulated with 600ff capacitive load and 30 100ua switches gives 150mv pp swing at 750ps period for the euterpe style clock, cgde.., 30 100ua switches is 3ma of switch current fed by the clock driver, 3000ma/60 is 50ua base current at a beta of 60.. in the case of the clock is the diffusion capacitance that it has to drive. At 920ps period we get about 170mv pp swing with 35 100ua switch loads. The clock driver is a 250mv 150ua switch, with 50ua steady state and 750ua switched emitter follower current. A reasonable extra dc load would be 150ua \* 1/10 = 900 ua, so i guess i am saying that the switched load emitter current should be less than 3.5ma, (3500ua/60) = 58ua actual effective base load. The clock driver is a 2p level

bill (William Herndon)

and has to go directly into a switch...

From:

Sent:

From:
ong (Warren R. Ong)

Sent:
Thursday, January 26, 1995 10:51 AM

'Drew Wingard'
'fwo (Fred Obermeier)'; 'geert (Geert Rosseel)'

Subject:
Re: vy differential drivers?

>From Drew Wingard ...

```
@ Fred wrote (sorry about the delay...):
@ > My question is that Drew wanted me to disallow differential inputs to be @ > driven
from complementary outputs coming from different instances. If we @ > want to allow this
type of hook-up, I think that I'll need to change the @ > code to find all pairs of
drivers for each instance.
@ >
@ > Should for example, the following be legal?
@ >
@
 >
@
           a a0pfwy >---->
                                              d ad0ph
@
 >
@
     a_an0pfwy >-----
 >
@
 >
@
           b_a0phwy >----
 > I2
@
@
     b_an0phwy >----
@ >
@
@ I think that the above case should be legal, although I suspect that it @ doesn't occur.
```

@ I think that the above case should be legal, although I suspect that it @ doesn't occur.

I would think otherwise about letting this be legal. What if a\_a0pfwy and a\_an0pfwy do not slew at the same time, and it results in both inputs being low for several gate delays? This could saturate the receiving circuit, and for bicmos designs, might trigger latch up.

@ I'm quite sure that Warren's case should be legal, but I think that @ it uses a 'custom' swing rather than a 'h' or 'f'. Since our standard @ cells don't have 'w' nor 'y' qualifiers, this can't happen there.

In the case of the exlax memory cells, the memory cells themselves are the drivers and they \*are\* differential. The other circuit connected to the rbl\_abn\*d0p85vy signal is the input of dout circuit. I do not expect this net to ever be driven by complementary and non-differential signals.

So, if the above example never occurs, and it is not desirable, then we should be able to disallow it without affecting the results from Euterpe.

```
@ I think that the presence of 'w' or 'y' on the drivers should probably @ enable an enhanced checking algorithm that pairs up the drivers.
@ Is this expensive to implement?
@
@ Sorry again for the delay,
@ Drew
```

Warren.

```
From: vo (Tom Vo)
```

Sent: Thursday, January 26, 1995 11:56 AM

To: 'Tim B. Robinson'

Subject: Re: euterpe/verilog/bsrc/ce cerberus.cpif

```
Tim B. Robinson wrote ....

> 
> 
> Tom Vo wrote (on Wed Jan 25):

> Update of /p/cvsroot/euterpe/verilog/bsrc/ce

> In directory ghidra:/s5/vo/euterpe/verilog/bsrc/ce

> Modified Files:

> cerberus.cpif

> Log Message:

> moved octlet 6. This version is electrically no good, but has the right

> number of wires through the choke points. More work is needed.

> 
> Is it still logically OK?

> 
> Tim
```

Probably not . I need to redo the clock buffering going to this octlet and octlet 10. There're also performance related edits for outputs to toplevel to be performed .

tvo

jeffm (Jeff Marr)

Sent:

Thursday, January 26, 1995 5:15 PM

To:

'lisar'; 'veena'; 'doi'; 'karzes'

Cc:

'tbr'; 'dickson'

Subject: illegal group shift/rot/exp/comp immediates

This is a followup to the question of whether the the following are exception or don't care cases:

The immediate shift amount is greater than, or equal to, the size for group shift, rotate, expand, and compress immediates.

Dickson did not implement these as trap cases - they are don't cares.

Terp is implemented the same way.

The assembler does not complain about the cases, nor does it truncate them.

The TSA of 14 April, pg 109, indicates that these should be reserved instruction exceptions.

Whatlitbe?

jeffm

Tom Karzes [karzes@scylla]

Sent:

Thursday, January 26, 1995 5:52 PM 'craig@scylla'; 'tbr@scylla'; 'jeffm@scylla'

To: Cc:

'lisar@scylla'; 'veena@scylla'; 'doi@scylla'; 'dickson@scylla'

Subject:

[jeffm: illegal group shift/rot/exp/comp immediates]

#### Jeff Marr writes:

> This is a followup to the question of whether the the following are > exception or don't care cases:

>

The immediate shift amount is greater than, or equal to, the size for group shift, rotate, expand, and compress immediates.

>

- > Dickson did not implement these as trap cases they are don't cares.
- > Terp is implemented the same way.
- > The assembler does not complain about the cases, nor does it truncate
- > them.
- > The TSA of 14 April, pg 109, indicates that these should be reserved
- > instruction exceptions.
- > Whatlitbe?

One correction here: For expand and compress, the exception should only be generated if the shift amount is greater than, or equal to, the larger of the two group sizes involved. This is the most natural group size, and is what is used in the XLU interface, but for historical reasons the instruction encoding uses the smaller group size. So for these cases, the exception would be generated if the shift amount is >= twice the group size. Note that this was a change: At an earlier time, the limit was the smaller group size, which explains the historical encoding.

As far as not supporting out-of-range exceptions for immediate shift amounts, I believe this is a departure from the Terpsichore architecture. As far as I know, out-of-range immediate shift amounts were always supposed to generate exceptions. The XLU microarchitecture notes that I wrote were very unclear about this (they simply noted that the XLU would ignore any bits beyond the valid range, and in fact the XLU doesn't even know when it's being given an immediate vs. a non-immediate shift amount). However, I had always assumed that the trap conditions would be implemented according to the architecture manual.

At this point, I think we need to answer the following questions:

- 1. How important is it to fix this, i.e., add the exceptions?
- 2. How much work would be involved in fixing it?
- 3. If we don't fix it, should the assembler mask off the bits which are ignored, possibly with a worning, to make it easier to make these reserved in the future?

wingard (Drew Wingard)

Sent:

Friday, January 27, 1995 2:42 AM

To:

'thr'

Cc: Subject: 'geert'; 'hopper'; 'tom' Re: HTML stuff

Tim wrote:

> Please see ken tomorrow to get what you need done. Eric is sending

> him some pointers.

#### Great!

> Meantime, please explain the problem again. Lisar has a bunch of

- > linked pages set up in the veryfy area. With no special macros or
- > anything, we appear to able to navigate OK up and down across symlinks
- > just as i think one would want. (ie not the same as what the
- > corresponding set of cd's would have done). Furthermore, we seem to
- > be able to reach any file in the filesystem.

>

- > I thought from what you had said that a) you could only see things in
- > a few restricted places, and b) once you had gone down a symlink you
- > got lost comming back up.

I'll be glad to take a shot at explaining it.

Mosaic (as a WWW client) presents two basic ways to access external files. Well, actually it gives a lot more, but I think only two are really useful to us.

Most HTML documents are served from external machines, and the preferred (both in terms of performance and features) method of access to files on external machines is via the HyperText Transfer Protocol (HTTP). Here the Mosaic client communicates over a 'well-known' port (typically port 80) to the 'httpd' daemon on the remote machine. The 'httpd' process typically runs as the user 'nobody' to limit its permissions, and furthermore has tight restrictions on where in its filesystems it will look for files to serve to the outside world.

This is the origin of the restriction "a) " that you note above.

The primary alternate method we could consider using (and the one we were using until bobm found WebStar), is called the "file" access method.

Here, Mosaic will look on the locally-accessible file systems (with the permissions associated with the user invoking Mosaic) if the 'remote' machine associated with the link is specified as the local machine (i.e. 'file://localhost' at the beginning of the Universal Resource Locator (URL) that points to the file).

This sounds really convenient and good, and it is as long as:

- 1) you can decide at the time you create/install the document where all the files that you might want to link to will be located.
- you never need to pass any link-specific arguments to any commands that you might want to call

The problem, as I saw it, with the first restriction is that if our documentation is to truly be a 'first-class' design database component that it should follow the basic rules that our other components do.

In particular, we have gone to quite a bit of effort to build a system that allows user to check out only a subset of the entire design space and yet operate as if the entire design were at hand. We've done this, at least in part, through liberal use of symbolic links.

But we have problems when folks try to point to another file using paths like ../another\_dir/file because you end up in a different place than expected if .. doesn't point to the same place from which the symbolic link came.

A major mechanism that we use to get past this is to express many paths as relative to \$CHIPROOT.

When I tried to set up the documentation using \$CHIPROOT and "file:"

it became apparent that I had a problem. Since Mosaic reads "file:" HTML files without passing them through any filters there was no simple way for me to dynamically change \$CHIPROOT-relative links to match any given user's setup. My best alternative was to 'compile' CHIPROOT into each HTML file in a Makefile-directed process. Thus, files in a checked out tree would have the correct value for that tree, but files in symbolically-linked directories would have CHIPROOT set to /u/chip/something (typically). This concerned me not only because it could be confusing to a designer, but also because I wanted a reliable way to get back to a checked-out design's "home page" from every document, and I clearly couldn't get there from a pointer to the 'wrong' CHIPROOT.

The alternative is to try to use a true relative path from everywhere. However, I found that the Mosaic I was running did something unexpected: on "http:" accesses the Mosaic client itself interprets dir/../other\_dir - style paths, collapsing the path before sending it to the server.
"File:" accesses, on the other hand, didn't always get collapsed before going to the file system.

Thus, paths such as "verilog/../compass/cell.html" got passed to the file system and thus ran into the symbolic link problem that caused us to want CHIPROOT in the first place. Even if we modified Mosaic not to do this, do we really want to use relative paths all over the place? Sigh...

OK, so how do we fix this problem? One idea was to modify Mosaic to pre-process all HTML files it receives and do a 'sed'-style string substitution on all CHIPROOT strings that it saw. Of course we'd also need to teach Mosaic how to learn the desired value of CHIPROOT, and probably also how to modify it during a session. Seemed like a hack, and a painful one at that.

Then bobm found WebStar. WebStar is a program started by the httpd server. One of the benefits of being started by httpd, rather than by Mosaic itself, is that the forked program can take arguments that are specified in the HTML link itself. An invoked WebStar parses all of the arguments passed to it and looks for ones which specify an HTML file to return. However, WebStar processes the file before returning the file to Mosaic it looks for embedded Tcl commands to execute. The Tcl commands typically use the arguments that were passed to WebStar to modify the contents of the returned document.

In our case, an obvious use of WebStar is to handle the CHIPROOT problem. If one of the arguments to WebStar is always the currently-defined CHIPROOT, then WebStar can easily substitute that value into the documents that it returns. Thus WebStar gives our documents the ability to store state.

Which brings us to the other reason why I don't think "file:" access is a good choice. Mosaic has a mechanism to start up commands to 'view' non-html documents. For instance, bobm uses this mechanism to fire up Frame to look at files ending in .mif. A significant problem for some of the applications that we might want to start (like Concept) is that the returned file gets a computer-generated name (i.e. rather than simply passing xlu.mif to Frame, Mosaic copies xlu.mif to /tmp/aaaa2134.mif and passes the tmp file to Frame). So, for a program like Concept that wants to start up in a specific directory one might want to instead have Mosaic run a shell script that did the 'right' thing. Unfortunately, since Mosaic won't pass that script any HTML-specified arguments (not even the name of the original script) the resulting script needs to 'know' everything about what it needs to do. Such as the full path of the directory where the actual design file(s) live.

I thought doubling the number of design files (i.e. one script per design source file) sounded like a bad idea.

An alternative would be to use "file:" accesses for HTML files and "http:" accesses to start up helper scripts to access other design files. Unfortunately, specifying the path to the other files is problematic. You see, there's no way to feed a "http:" reference a path that is relative to the current "file:" access. So by using "http:" we gain the ability to pass arguments, but we lose the ability to specify relative paths. Sigh...

But WebStar can help us with this. Since the HTML files are accessed through "http:", we can encode state in the returned files. This state can then be passed to the helper scripts. And then the helper scripts can return the proper data to Mosaic so it can start up the proper local application to load the proper design file.

And we intend the user interface to be very simple macro calls. For instance, "to see the Makefile definitions click CHIPREF(here, Makefile.defs)" or "to look at the schematic click CONCEPT(here, camcell) and to examine the layout click COMPASS(here, \$CHIPROOT/compass, camcell)".

Note that the latter two macros have not been implemented yet, but should be relatively soon.

I hope some of this makes sense. It certainly took a while to type!

#### Drew

P.S. - there may be security risks associated with given WebStar access to the filesystem. I don't think WebStar can do anything worse than return (potentially) every file readable by the user 'nobody'. In particular, I don't think a remote user can cause any other programs to get executed on the server side. Anything which might get executed on the client side is of course executed as the user running Mosaic.

tbr (Tim B. Robinson)

Sent:

Friday, January 27, 1995 10:49 AM

To: Cc: 'wingard (Drew Wingard)' 'geert'; 'lisar'; 'hopper'; 'tom'

Subject:

Re: HTML stuff

Drew Wingard wrote (on Fri Jan 27):

#### Tim wrote:

- > Please see ken tomorrow to get what you need done. Eric is sending
- > him some pointers.

#### Great!

- > Meantime, please explain the problem again. Lisar has a bunch of
- > linked pages set up in the veryfy area. With no special macros or
- > anything, we appear to able to navigate OK up and down across symlinks
- > just as i think one would want. (ie not the same as what the
- > corresponding set of cd's would have done). Furthermore, we seem to
- > be able to reach any file in the filesystem.

>

- > I thought from what you had said that a) you could only see things in
- > a few restricted places, and b) once you had gone down a symlink you
- > got lost comming back up.

I'll be glad to take a shot at explaining it.

Mosaic (as a WWW client) presents two basic ways to access external files. Well, actually it gives a lot more, but I think only two are really useful to us.

Most HTML documents are served from external machines, and the preferred (both in terms of performance and features) method of access to files on external machines is via the HyperText Transfer Protocol (HTTP). Here the Mosaic client communicates over a 'well-known' port (typically port 80) to the 'httpd' daemon on the remote machine. The 'httpd' process typically runs as the user 'nobody' to limit its permissions, and furthermore has tight restrictions on where in its filesystems it will look for files to serve to the outside world.

This is the origin of the restriction "a) " that you note above.

The primary alternate method we could consider using (and the one we were using until bobm found WebStar), is called the "file" access method. Here, Mosaic will look on the locally-accessible file systems (with the permissions associated with the user invoking Mosaic) if the 'remote' machine associated with the link is specified as the local machine (i.e. 'file://localhost' at the beginning of the Universal Resource Locator (URL) that points to the file).

This sounds really convenient and good, and it is as long as:

- you can decide at the time you create/install the document where all the files that you might want to link to will be located.
- 2) you never need to pass any link-specific arguments to any commands that you might want to call

The problem, as I saw it, with the first restriction is that if our documentation is to truly be a 'first-class' design database component that it should follow the basic rules that our other components do. In particular, we have gone to quite a bit of effort to build a system that allows user to check out only a subset of the entire design space and yet operate as if the entire design were at hand. We've done this, at least in part, through liberal use of symbolic links.

But we have problems when folks try to point to another file using paths like ../another\_dir/file because you end up in a different place than expected if .. doesn't point to the same place from which the symbolic link came. A major mechanism that we use to get past this is to express many paths as relative to \$CHIPROOT.

This is the point I was having trouble with, because when I tried this, ../blah did what I think I wanted, not what I expected. ie it did not do the same as cd would have done. So I could go down my local tree and through a link to something, then follow a pointer with .. in it and get back to where I was even thought there was a symlink.

When I tried to set up the documentation using \$CHIPROOT and "file:" access

it became apparent that I had a problem. Since Mosaic reads "file:"

files without passing them through any filters there was no simple way for me to dynamically change \$CHIPROOT-relative links to match any given user's setup. My best alternative was to 'compile' CHIPROOT into each HTML file in a Makefile-directed process. Thus, files in a checked out tree would have the correct value for that tree, but files in symbolically-linked directories would have CHIPROOT set to /u/chip/something (typically). This concerned me not only because it could be confusing to a designer, but also because I wanted a reliable way to get back to a checked-out design's "home page" from every document, and I clearly couldn't get there from a pointer to the 'wrong' CHIPROOT.

The alternative is to try to use a true relative path from everywhere. However, I found that the Mosaic I was running did something unexpected:

on "http:" accesses the Mosaic client itself interprets dir/../other\_dir - style paths, collapsing the path before sending it to the server.
"File:" accesses, on the other hand, didn't always get collapsed before going to the file system.

Thus, paths such as "verilog/../compass/cell.html" got passed to the file system and thus ran into the symbolic link problem that caused us to want CHIPROOT in the first place. Even if we modified Mosaic not to do this, do we really want to use relative paths all over the place? Sigh...

#### Probably not.

OK, so how do we fix this problem? One idea was to modify Mosaic to pre-process all HTML files it receives and do a 'sed'-style string substitution on all CHIPROOT strings that it saw. Of course we'd also need to teach Mosaic how to learn the desired value of CHIPROOT, and probably also how to modify it during a session. Seemed like a hack, and a painful one at that.

Then bobm found WebStar. WebStar is a program started by the httpd server. One of the benefits of being started by httpd, rather than by Mosaic itself, is that the forked program can take arguments that are specified in the HTML link itself. An invoked WebStar parses all of the arguments passed to it and looks for ones which specify an HTML file to return. However, WebStar processes the file before returning the file to Mosaic - it looks for embedded Tcl commands to execute. The Tcl commands typically use the arguments that were passed to WebStar to modify the contents of the returned document.

In our case, an obvious use of WebStar is to handle the CHIPROOT problem. If one of the arguments to WebStar is always the currently-defined CHIPROOT, then WebStar can easily substitute that value into the documents that it returns. Thus WebStar gives our documents the ability to store state.

Which brings us to the other reason why I don't think "file:" access is a good choice. Mosaic has a mechanism to start up commands to 'view' non-html documents. For instance, bobm uses this mechanism to fire up

Frame to look at files ending in .mif. A significant problem for some of the applications that we might want to start (like Concept) is that the returned file gets a computer-generated name (i.e. rather than simply passing xlu.mif to Frame, Mosaic copies xlu.mif to /tmp/aaaa2134.mif and passes the tmp file to Frame). So, for a program like Concept that wants to start up in a specific directory one might want to instead have Mosaic run a shell script that did the 'right' thing. Unfortunately, since Mosaic won't pass that script any HTML-specified arguments (not even the name of the original script) the resulting script needs to 'know' everything about what it needs to do. Such as the full path of the directory where the actual design file(s) live.

I thought doubling the number of design files (i.e. one script per design source file) sounded like a bad idea.

An alternative would be to use "file:" accesses for HTML files and "http:" accesses to start up helper scripts to access other design files. Unfortunately, specifying the path to the other files is problematic. You see, there's no way to feed a "http:" reference a path that is relative to the current "file:" access. So by using "http:" we gain the ability to pass arguments, but we lose the ability to specify relative paths.

Sigh...

But WebStar can help us with this. Since the HTML files are accessed through "http:", we can encode state in the returned files. This state can then be passed to the helper scripts. And then the helper scripts can return the proper data to Mosaic so it can start up the proper local application to load the proper design file.

And we intend the user interface to be very simple macro calls. For instance, "to see the Makefile definitions click CHIPREF(here, Makefile.defs)" or "to look at the schematic click CONCEPT(here, camcell) and to examine the layout click COMPASS(here, \$CHIPROOT/compass, camcell)".

Note that the latter two macros have not been implemented yet, but should be relatively soon.

I hope some of this makes sense. It certainly took a while to type! Yes, it's a big help.

P.S. - there may be security risks associated with given WebStar access to the filesystem. I don't think WebStar can do anything worse than return (potentially) every file readable by the user 'nobody'. In particular, I don't think a remote user can cause any other programs to get executed on the server side. Anything which might get executed on the client side is of course executed as the user running Mosaic.

From: wampler (Kurt Wampler)

Sent: Friday, January 27, 1995 11:19 AM

To: 'tbr

Cc: 'brianl'; 'ericm'; 'tom'; 'wampler'

Subject: Re: gardswart makefile problem in snapshot?

I suppose since the original mail on this subject was addressed to me that a response is due. :-) I think most questions have already been answered but I will try to collate & summarize in a single e-mail. Here goes...

- Kurt

### tbr writes:

>Howcome this has never shown up in any other use of v2e. We use it a >lot, with the standard definitions from Makefile.defs. Also, are we >sure we are not throwing the baby out with the bath water here? The >whole reason for rexec existing in the first place was to try and >reduce the actually use of rsh in the typical case because of the name >resolution problem.

# tom responds:

>Actually, it did show up once before, some months ago -- tom vo had the >core-dumping problem that time, if I recall correctly. The core-dump >only occurs when a global 'export' is used in the Makefile, the remote >machine is the same as the local machine, and the user's login shell >has a low tolerance for large environments (tcsh has the problem; sh >doesn't; not sure about others).

## wampler responds:

I volunteer to look at the source code for tesh to see if I can make it insensitive to large environment. It shouldn't core dump!

The gardswart Makefile did not exhibit this problem before because it was relying on the default behavior of the /u/chip/tools/bin/v2e wrapper; its default was always to rexec to staypuft to run v2e. The proteus/Makefile.rules didn't exhibit this problem because it wasn't doing a global export of Make variables and thus did not crash the local shell (for those users using tesh, and possibly csh).

### tbr continues:

><Entering pontification mode>
> I still feel it would be prefererable to export only those things
>you really need with
> export VAR1
> export VAR2
> tc. In the general case, the global export makes it
> impossible to use the construct
>

Exhibit C10

>FOO = \$(shell <some command that takes a long time>)

>because it causes an infinite recursion. (Make tries to put it in the >enviornment before invoking the shell, but to calculate the value it >needs to invoke the shell. One might call that a bug in gmake.)

>Using := is not good in the case that the shell command takes a long time >and is only needed for a specific rule. I ran into this when the >'export' suddenly popped up in the euterpe/Makefile.share. In that >case the shell command took 15 ninutes and was being invoked with >every make run even though I only needed the result for one particular >target.

><Leaving pontification mode>

# wampler responds:

My goals in using gmake's global export were:

- 1) Satisfy the requirement that the shell scripts used in the gardswart build process be sensitive to the tool definitions in Makefile.defs. I experimented with writing a shell script to parse Makefile.defs, but abandoned this because it cannot accurately reproduce the complete list of Make variables, since it doesn't know which ones have been overridden by a local Makefile, command-line overrides, etc.
- 2) Decouple maintenance of gardswart shell scripts from the gardswart Makefiles. Using the explicit export model requires a coordinated change to the Makefile any time the shell script needs to pick up a new variable. Also, since these shell scripts tend to invoke a number of tools, the number of variables needing to be explicitly passed to the script is large (order 20 variables), and I wanted to avoid the ugliness of that long list of variables in the Makefile every time it calls a script. And, of course, each script requires a different subset of the variables.

#### ericm comments:

>i could have rexec stop the environment before exec() but kurt >and tom's feeling was that it'd be better to have consistent behaviour >by always doing the rsh instead.

### wampler agrees:

I think consistent behavior, regardless of whether the host specified happens to be local or not, is of paramount importance.

# tbr wonders:

>(As an asside, whats the performace hit of passing a huge environment >each time there is a fork()? In BSD at least it used to be horrible >with it getting probed and copied one character at a time. I would >hope it's been tuned some since then.)

### wampler responds:

My experience in using this export has been that the performance hit is not noticeable. Invocations of individual tools zoom by just as fast as they used to. I could devise an experiment to measure this overhead if we need to quantify it.

### tom clarifies:

>I recall the main purpose of rexec being to get back the exit status of >the remote process. The old rexec (ericm has changed this), by avoiding >the rsh when the remote machine was the local machine, had the effect of >potentially inconsistent behavior. The environment was passed to the >program if remote-machine == local-machine, but wasn't otherwise.

# wampler responds:

I recall this also as the primary design goal of rexec -- to provide a robust, consistent replacement for "rsh", which properly returns the exit status of the remote command.

### tom proposes:

>It might be nice to have a program like rexec that made the remoting be >really transparent (passing environment, current directory, etc)...

# wampler seconds:

I agree this would be a useful feature, either as a switch on the current rexec or as a separate parallel script.

```
Sent:
                     Saturday, January 28, 1995 12:59 PM
To:
                     'Tim B. Robinson'
                     'sysadmin@gaea'; 'geert@gaea'
Cc:
Subject:
                     Re: forwarded message from Geert Rosseel
At 11:37 AM 1/28/95, Tim B. Robinson wrote:
>Can someone reboot godzilla, gamorra, ghidra and mothra please?
>They all have the NFS stale file handle problem for auspex:/s41 which
>is unfortunately one of the main Euterpe partitioins.
>They all seem to be idle at present (not surprising since they can't
>get to s41.
>Tim
>----- Start of forwarded message -----
>Status: RO
>X-VM-v5-Data: ([nil nil nil nil t nil nil nil nil]
         ["146" "Sat" "28" "January" "1995" "11:25:06" "-0800" "Geert
>Rosseel" "geert " "<199501281925.LAA17619@ambiorix.microunity.com>" "5"
>"Re: auspex" "^From:" nil nil "1"])
>Return-Path: <geert>
>Received: from ambiorix.microunity.com by gaea.microunity.com
(4.1/muse1.3)
         id AA23095; Sat, 28 Jan 95 11:25:07 PST
>Received: from localhost by ambiorix.microunity.com (8.6.4/muse-sw.3)
         id LAA17619; Sat, 28 Jan 1995 11:25:06 -0800
>Message-Id: <199501281925.LAA17619@ambiorix.microunity.com>
>From: geert (Geert Rosseel)
>To: tbr
>Subject: Re: auspex
>Date: Sat, 28 Jan 1995 11:25:06 -0800
   godzilla, gamorra, ghidra and mothra have problems getting to s41
   The other big machines seem to be O.K.
>----- End of forwarded message -----
Done.
------
```

fgp@microunity.com

Frank Paturzo [fgp@gaea]

Frank Paturzo

From:

tbr (Tim B. Robinson)

Sent:

Saturday, January 28, 1995 2:18 PM

To:

'Frank Paturzo'
'geert'; 'sysadmin'

Cc: Subject:

Re: forwarded message from Geert Rosseel

Frank Paturzo wrote (on Sat Jan 28):

At 11:37 AM 1/28/95, Tim B. Robinson wrote: >Can someone reboot godzilla, gamorra, ghidra and mothra please? >They all have the NFS stale file handle problem for auspex:/s41 >which is unfortunately one of the main Euterpe partitioins. >They all seem to be idle at present (not surprising since >they can't get to s41.

Done.

Thanks.

Tim

From: chip (Buffalo Chip)

Sent: Saturday, January 28, 1995 2:29 PM

To: 'wampler'

Cc: 'tbr'

Subject: Problem with Euterpe Top-level build

Hi,

PCOMP died while trying to build the clockbias for the euterpe baseplate. This is urgent. It is stopping the build of both the build of the latest top-level and of the small euterpe for DRC/LVS.

Geert

From: lisar (Lisa Robinson)

Sent: Saturday, January 28, 1995 2:31 PM

To: 'woody'

Cc: 'billz'; 'dickson'; 'jeffm'; 'mws'; 'tbr'

Subject: dcacheharder

Jay there is a dump of dcacheharder\_V in /u/tbr/euterpe/verilog/bsrc. It goes to X. dcacheharder\_0 seemed to hang (ie behave differently) so I have that running in verilog too.

Lisa R.

From: Sent:

Geert Rosseel [geert@rhea] Saturday, January 28, 1995 2:31 PM 'geert@rhea' pager log, sender copy

To:

Subject:

page from geert to wampler: Read mail on top-level Euterpe : clockbias problem . Thanks.. geert

tbr (Tim B. Robinson)

Sent:

Saturday, January 28, 1995 2:53 PM

To:

'geert' 'wampler'

Cc: Subject:

Problem with Euterpe Top-level build

Buffalo Chip wrote (on Sat Jan 28):

Ηi,

PCOMP died while trying to build the clockbias for the euterpe baseplate. This is urgent. It is stopping the build of both the build of the latest top-level and of the small euterpe for DRC/LVS.

I wonder if this could be in any way related to the dot in the path problem recently changed int he clockbias stuff. Do you have the logfile with the failure?

Tim

From: vanthof (vant)

Sent: Saturday, January 28, 1995 3:44 PM

To: 'geert (Geert Rosseel)'; 'stick (Bruce Bateman)'; 'bpw (B. P. Wong)'

Cc: 'vanthof (Dave Van't Hof)'; 'solo (John Campbell)'; 'tom (Thomas Laidig)'; 'Eldred Felias'; 'Mark

Hofmann'; 'Tim B. Robinson'

Subject: cache drc errors

The cache has about 4.7MB of drc errors;

min active dimension in the long direction = 18 min emitter feature space = 18 min emitter implant sapce = 10 min collector plug spacing = 18 min metal1 - metal4 min concave edge length = 20

The majority of the errors fall into the first 3 categories. I've looked at a few, but the fixes are not immediately obvious and require a better knowledge of the interactions of these layout cells. I can keep looking at them, but I don't think I'll do any edits.

The error file is: /u/vanthof/compass/mobi/euterpe/cache.err

What sort of impact would waiting until monday to have a real mdunit look at these errors have on the generation of the baseplate?

My personal preference would be to have a chip generated so I can start some sort of drc/lvs runs. It has been many many months since this has been done.

Thanks, Dave

Dave Van't Hof vanthof@microunity.com MicroUnity Systems Engineering, Inc. 255 Caspian Way, Sunnyvale, CA (408) 734-8100 X276 #include <std\_disclaim.h> Don't blame me, I didn't vote for him!

tbr (Tim B. Robinson) From: Sent: Saturday, January 28, 1995 3:52 PM 'geert (Geert Rosseel)' To: 'wampler' Cc: Subject: Re: Problem with Euterpe Top-level build Geert Rosseel wrote (on Sat Jan 28): Hi Tim, The output of the make is in /n/auspex/s41/euterpe-snapshot/euterpe/euterpe.out I am not familiar with the change that you mention. I paged Kurt to look at this but he has not responded yet. It's in the area I thought, but I don't see what's wrong. Here's the rule that failed: # Make the CDL placement rules cbsofa\_cdl: cbsofa\_exclude.ly cbsofa\_mask.ly cbmacros.pdl \ \$(CPROTO)/get\_profiles cbsofacdl \$(CPROTO)/get\_profiles cbmacros.pdl > profiles.txt ./cbsofacdl profiles.txt cbsofa\_exclude.ly > cbsofa.cdl The problem is that the binary that's there is not executable. I think that must mean it failed to link correctly. I'll try removing it and see if it

will rebuild.

tbr (Tim B. Robinson)

Sent:

Saturday, January 28, 1995 3:55 PM

To:

'geert (Geert Rosseel)'

Cc:

'wampler'

Subject:

Re: Problem with Euterpe Top-level build

Geert Rosseel wrote (on Sat Jan 28):

Hi Tim,

The output of the make is in /n/auspex/s41/euterpe-snapshot/euterpe/euterpe.out

I am not familiar with the change that you mention. I paged Kurt to look at this but he has not responded yet.

Well, I have no idea why it was not executable. I removed it and it remade OK:

gmakechip@mothra /N/auspex/root/s41/euterpe-snapshot/euterpe/clockbias 12 % cbsofacdl
/n/auspex/s41/euterpe-snapshot/euterpe/proteus/clockbias/gsub
cbsofa\_bounds.gsub \

/n/auspex/s41/euterpe-snapshot/euterpe/proteus/clockbias/cbsofacdl.c.templ
ate > cbsofacdl.c
gcc -g cbsofacdl.c -o cbsofacdl
chip@mothra /N/auspex/root/s41/euterpe-snapshot/euterpe/clockbias 13 % ls -ls !\$ ls -ls
cbsofacdl
160 -rwxr-xr-x 1 chip 147605 Jan 28 13:53 cbsofacdl

So, I think if you re-run your make from the top it should get past it.

Tim

tbr (Tim B. Robinson)

Sent:

Saturday, January 28, 1995 3:57 PM

To:

'geert (Geert Rosseel)'

Cc:

'wampler.'

Subject:

Top-level Euterpe

Geert Rosseel wrote (on Sat Jan 28):

Hi, I think I may have found the problem. The make died yesterday because of a permission problem but it wrote an empty file that did not get rebuild.

It wasn't empty:

320 -rw-rw-rw-

1 chip cad 147605 Jan 27 10:47 cbsofacdl

but then it wasn't executable either. The new version is the same size:

ls -ls cbsofacdl

160 -rwxr-xr-x 1 chip

147605 Jan 28 13:53 cbsofacdl

Tim

wampler (Kurt Wampler)

Sent: Saturday, January 28, 1995 7:03 PM To:

'geert'; 'tbr'

Subject:

Re: Top-level Euterpe

> I deleted the clockbias directory, got a BOM and rebuild. That got me >up to placement but the clock generation fails here. Kurt, can you look >at this, please ...

Sorry to be so long in responding; I was out most of the afternoon. I think the reason the gplace/clockbias was failing is because thoas's X-server died last night during the auspex reboot. (By default it directs the display at thoas.) I've restarted thoas's X-server, and it should work now. It is also possible to override the DISPLAY pointer on the gmake command line as well, if this problem recurds in the future.

- Kurt

From: lisar (Lisa Robinson)

Sent: Saturday, January 28, 1995 10:36 PM

To: 'billz'; 'dickson'; 'mws'; 'woody'

Cc: 'jeffm'; 'tbr'

Subject: Dump that are availble

The following dumps are available -

/u/tbr/euterpe/verilog/bsrc/dcacheharder\_V.dump /u/tbr/euterpe/verilog/bsrc/dcacheharder\_0.dump /n/nosfaeratu/s2/euterpe/verilog/bsrc/dcache\_func\_1.dump

Lisa R.

From: woody (Jay Tomlinson)

Sent: Sunday, January 29, 1995 1:12 AM

To: 'lisar (

'lisar (Lisa Robinson)'

Cc:

'billz'; 'dickson'; 'jeffm'; 'mws'; 'tbr'

Subject: Dump that are availble

Lisa Robinson wrote (on Sat Jan 28):

The following dumps are available -

/u/tbr/euterpe/verilog/bsrc/dcacheharder\_V.dump /u/tbr/euterpe/verilog/bsrc/dcacheharder\_0.dump /n/nosfaeratu/s2/euterpe/verilog/bsrc/dcache\_func\_1.dump

### Lisa R.

I looked at dcacheharder\_V. I got tired and didn't finish this one, but what I found is that nb put out a packet of all x's except for the tag. I suspect that nb read an unused entry. There is a ut file in /u/woody/chip/euterpe/verilog/bsrc/dcacheharder.ut that has markers at the problem.

jay

From: billz (Bill Zuravleff)

Sent: Sunday, January 29, 1995 11:17 AM

To: 'lisar (Lisa Robinson)'; 'tbr (Tim B. Robinson)'; 'mws (Mark Semmelmeyer)'; 'Jay Tomlinson';

'Richard Dickson'

Subject: bsrc BOM 214.4 fab's

Y'all,

For me, bsrc BOM 214.4 fab's on tests dcacheeasy\_V, dcacheharder\_V, dcacheannoying\_V. (results in ~billz/euterpe/verilog/bsrc).

Regards, billz

Page 322 of 356

From: lisar (Lisa Robinson)

Sent: Sunday, January 29, 1995 12:43 PM

To: 'billz (Bill Zuravleff)'

Cc: 'dickson (Richard Dickson)'; 'mws (Mark Semmelmeyer)'; 'tbr (Tim B. Robinson)'; 'Jay Tomlinson'

Subject: bsrc BOM 214.4 fab's

Bill Zuravleff wrote (on Sun Jan 29):

Y'all,
For me, bsrc BOM 214.4 fab's on tests
dcacheeasy\_V, dcachearder\_V, dcacheannoying\_V.
(results in ~billz/euterpe/verilog/bsrc).

Regards, billz

Thats great. I'm having problems with unreproducible simulation results again. However I do have the following dumps:

/u/tbr/euterpe/verilog/bsrc/icacheannoying\_0.dump /n/nosferatu/s2/euterpe/verilog/bsrc/saaseasy\_0.dump /n/nosferatu/s2/euterpe/bsrc/dcache\_func\_1.dump - but probably better to pick up 214.4 first.

Bill are you in a position to do a toplevel release?

Lisa R.

From: dickson (Richard Dickson)

**Sent:** Sunday, January 29, 1995 4:17 PM

To: 'tbr'
Subject: ????

tim,

does this have to do with the disk flux ???

Protocol error, gamorra.microunity.com closed connection mv: gards/es-pass3.gplace.lis: Cannot access: No such file or directory gmake[2]: \*\*\* [gards/es-pass3.gplace.lis] Error 1 gmake[2]: Leaving directory `/N/rama/root/s5/dickson/euterpe/verilog/bsrc/es' gmake[1]: \*\*\* [es-base.netcap] Error 1 gmake[1]: Leaving directory `/N/rama/root/s5/dickson/euterpe/verilog/bsrc/es' gmake: \*\*\* [esgards] Error 1

dickson

From: geert (Geert Rosseel)

Sent: Sunday, January 29, 1995 4:30 PM

To: 'sysadmin'

Cc: 'tbr'

Subject: Layout machines

All Compass machines have problems getting to /n/auspex/s23. This is where a large section of our chip databse lives. I guess they all need rebooting. :

euterpe, kephalos, millennium, athena, poseidon,

Geert

From: Frank Paturzo [fgp@gaea] Sunday, January 29, 1995 5:12 PM Sent: 'Geert Rosseel' To: 'sysadmin@gaea'; 'tbr@gaea' Cc:

Subject:

Re: Layout machines

At 2:30 PM 1/29/95, Geert Rosseel wrote: > All Compass machines have problems getting to /n/auspex/s23 . This is >where a large section of our chip databse lives. I guess they all need >rebooting. :

euterpe, kephalos, millennium, athena, poseidon,

Geert

Done.

\_\_\_\_\_ Frank Paturzo

fgp@microunity.com

From: lisar (Lisa Robinson)

Sent: Monday, January 30, 1995 12:23 PM

To: 'tbr'; 'tony'; 'dbulfer'; 'paulb'

Cc: 'mouss'

Subject: Pandora spec.

This note is just to make sure you are all in sync with respect to the specification(s) being written.

I have recommended to Paul that the document discussed in your Friday (1pm) meeting is re-named to be Pandora (Media) Workstation Engineering Specification.

Like the Hestia Specification this will contain a description of what Engineering is building. It will tie together data that has cross-functional implications. Eg, configuration, power dissipation, devices supported etc. It will be available on-line in the Pandora documentation tree. It will NOT contain target customer, target cost, reliability goals etc.

The document discussed later that afternoon will be entitiled Pandora (Media) Workstation Product Marketing Specification.

Also, since I am not sure that many people are aware of the Pandora notes and associated documentation I will email their location later today.

Lisa R.

Monday, January 30, 1995 1:37 PM Sent: To: 'geert (Geert Rosseel)' 'dickson (Richard Dickson)'; 'woody (Jay Tomlinson)'; 'tbr (Tim B. Robinson)' Cc: Subject: Re: Euterpe timing errors Geert wrote (on 17jan95): > Here are the timing violations of the latest top-level run. > This is the one that has lt between at & nb, and the re-arranged > More detailed info is in : /n/ghidra/s3/geert/euterpe/verilog/bsrc/gards/geert euterpe-top.stat > uu to au > \*\*\*\*\* > Warning! Cycle time exceeded by 29.74ps using cycle time of 926.00 HARD ERROR 3811 Iteration 1 Path After Optimization using cycle time of 926.00: uu/UwrapAuLvaSelUXR0/ul (xbhrdf32s 32S) Oport: Q\_AND0PF IntDel: swg: df delay: 266.04ps (force) RC 244.80 net: UUwrapAuLvaSelUXR0\_N<1> delay: 88.06ps lds: 7 pcap: 84.05ff cap: 469.27ff (ext) m2len: 0.00 m3len: 3502.00 m4len: 0.00 au/u203/u0 (xbor3dh32s 32S) Iport: D2 A0PF Oport: q\_andOph IntDel: 138.20 net: au/sfrc14b swg: dh delay: 9.81ps (force)
RC delay: 0.44ps lds: 1 pcap: 21.37ff cap: 49.27ff (ext) m2len: 64.00 m3len: 87.00 m4len: 0.00 au/u208/u0/u0 (xbmuxen2dh16s 16S) Iport: DO ADOPH Oport: q ad0ph IntDel: 72.60 net: au/u208/u0/m swg: dh delay: 8.09ps RC delay: 0.07ps lds: 1 pcap: 8.85ff cap: 20.55ff (ext) m2len: 30.00 m3len: 27.00 m4len: 0.00 (xbffdf4s 4S) Iport: D0\_ADMPH IntDel: au/u208/u0/u1 216.20 Time through Path: 955.74 In an earlier mail on the same path, I wrote: > I think this was once a 2 tick path because uu sent it out of an hr. > UU could decode the signal earlier so that the driving flop could be > local. However, because a muxenff macro was used, it really is a "3 > gate" path and is going to always remain a little stressed. Of course, if the path is only 30ps over with uu-au transmission, maybe the 3 gate path will work with a local flop in AU. Then would we tolerate a 3 gate path? Should we make this change?

mws (Mark Semmelmeyer)

From:

billz (Bill Zuravleff)

Sent:

Monday, January 30, 1995 2:50 PM

To:

'geert'

Subject:

Ře: nb status

The data in the snapshot may be different from /u/chip. You probably should point to the snapshot proteus to build the sub-blocks.

I don't understand.

You mean link my ~/euterpe/proteus to something\_other\_than\_u/chip/proteus

?

??? Surely, I don't want to be running down problems in an out-of-date portion of the data base.

billz

fwo (Fred Obermeier)

Sent:

Monday, January 30, 1995 3:50 PM

To:

'hardheads'

Cc:

naronead: 'fwo'

Subject:

Csyn Euterpe BOM 214 results.

Ηi,

Csyn results of tbr\_euterpe-pass1.splvs generated from bsrc BOM 214.0 indicates that there is an inconsistent phase connection. Excerpts are from /u/fwo/chip.bsrc/euterpe/verilog/bsrc/SAVE.214/\*.csyn

\_\_\_\_\_\_

ClockPhase (old style) checks:

error(1540), inconsistent phase in ckt top:

xpll0.ckfroot0\_alph

pleus.clockroot\_adlph

xpll0.ckfroot0 blph

pleus.clockroot\_andlph

error(1540), inconsistent phase in ckt top:

xpll1.ckfroot1 alph

pleuh.clockroot ad1ph

xpll1.ckfroot1\_blph

pleuh.clockroot\_and1ph

Please contact me if you have any questions on how to fix this.

The build of bsrc BOM 215 fail, so now I'm building 216 instead. Fred.

tbr

Sent:

Monday, January 30, 1995 8:55 PM

To:

'vo'

Subject:

Mnemo top level

Follow Up Flag: Follow up

Flag Status:

Red

I am debugging a version with the temp sensor, pll, knob city etc. Why is it we have vdde in the top level (using euterpe as an example), but not vsse?

From: wayne (Wayne Freitas)

Sent: Monday, January 30, 1995 8:59 PM

To: 'yves'; 'arya'; 'rmm'; 'dane'; 'graham'; 'tbr'; 'bill'

Subject: Voltage plane tests

Heres the initial data, I'll send this out to a larger group after I finishing adding some additional notes. Note, new test are on the bottom.

Wayne

#### TEST:

Continuation of basic power test. I'm going do a simple check of the PWB under static load conditions to see the voltage drop and temperature gradient across the board. Test conditions are as follows, Using a HP6651A linear power supply connected to the 3.3 volt input (where the DC-DC Module mounts) I will provide a constant voltage of 3.300VDC. Then using the HP6060B electronic load I will vary the load in 5amp increments upto 45amps. At each increment I will measure the temperature and voltage drop at specified points. This test will have the 6060B configured with transients "off", and have the external sense line "on" connected at the power input source.

Room temp =  $\sim$ 23 Degree +/-1, using a Fluke87 with 80T-IR probe. Load is currently only connected at Euterpe, as follows: using 3 sides with  $\sim$ 35 VCC via's 8ea. 28awg wire are brought up  $\sim$ .1" and then connected to a 12awg wire that run the perimeter of the Euterpe footprint. This is then connected by < 6" of 12awg wire to the load.

All voltage measurements are done using a Fluke87. Three points are measured at Calliope, Euterpe, and  $\sim 1$ " away form the Power Input.

| Volts | Amps       |                  | Points           |                  |
|-------|------------|------------------|------------------|------------------|
|       | -          | Eu               | Ca               | Po               |
| 3.30V | 1 <b>A</b> | 0.001, 3.299, 23 | 0.001, 3.300, 23 | 0.000, 3.300, 23 |
| 3.30V | 5A         | 0.005, 3.292, 23 | 0.003, 3.300, 23 | 0.000, 3.300, 23 |
| 3.30V | 10A        | 0.010, 3.283, 23 | 0.007, 3.298, 23 | 0.002, 3.299, 23 |
| 3.30V | 15A        | 0.015, 3.274, 26 | 0.011, 3.297, 24 | 0.002, 3.298, 26 |
| 3.30V | 20A        | 0.020, 3.265, 27 | 0.014, 3.296, 25 | 0.003, 3.297, 27 |
| 3.30V | 25A        | 0.025, 3.256, 27 | 0.018, 3.295, 25 | 0.004, 3.295, 29 |
| 3.30V | 30A        | 0.031, 3.248, 29 | 0.022, 3.294, 25 | 0.006, 3.294, 31 |
| 3.30V | 35A        | 0.036, 3.239, 31 | 0.025, 3.292, 25 | 0.006, 2.293, 33 |
| 3.30V | 40A        |                  |                  |                  |
| 3.30V | 45A        |                  |                  |                  |

# SUMMARY:

Seems the temperature gradient problem I had before was due to the shorted -sense trace dissipating into the polyamide. Voltage drop number seem alright considering all current is going through the Euterpe pins and only ~60% of VCC pins are connected. Will follow through after I add the same modification to Calliope pins. Tests will also expand to include additional test measurement points by the RF section. Numbers to be passed on to board layout engineers for verification.

2.1.2 voltages ==

Who: wayne

Date: Fri Jan 27 14:16:55 PST 1995

# TESTS:

Continuation of power distribution tests. The DC-DC module is now mounted on with the sense wire fix and a fan running to keep it cool. Currently I have the sense resistors loaded for Calliope I also found out that I needed to hardwire the VCC to the +sense because the lead actually connects to the VCC Output from Calliope.

Measurements will now be performed with a HP3457A Multimeter using a 4 wire measurement. 1st I'll duplicate my previous set-up and measurements to establish a correlation. I'm not going to do any temperature measurements because of the fan, and the measurement device doesn't seem to like the DC-DC Modules heat sink.

With the main board power off I did a simple sanity check, I've included them as "0A".

| Amps | Points         |                |                    |
|------|----------------|----------------|--------------------|
| _    | Eu             | Ca             | Po                 |
| 0A   | 0.00mV         | 0.00 mV        | $0.00 \mathrm{mV}$ |
| 1A   | 1.18mV, 3.810  | 0.90mV, 3.810  | 0.000, 3.813       |
| 5A   | 4.96mV, 3.336  | 3.27mV, 3.343  | 0.000, 3.344       |
| 10A  | 9.73mV, 3.333  | 6.32mV, 3.353  | 0.000, 3.355       |
| 15A  | 14.52mV, 3.341 | 9.37mV, 3.363  | 0.000, 3.367       |
| 20A  | 19.33mV, 3.344 | 12.42mV, 3.373 | 0.000, 3.378       |
| 25A  | 24.13mV, 3.346 | 15.48mV, 3.383 | 0.000, 3.389       |
| 30A  | 28.96mV, 3.349 | 18.54mV, 3.393 | 0.000, 3.400       |
| 35A  | 33.82mV, 3.353 | 21.65mV, 3.403 | 0.000, 3.411       |

I talked to Noel and got the following values for the chips. Nominal values given Calliope 17A @3.3V Euterpe 28A @3.3V

Same set-up as before except Calliope now has a power ring and I will be using a second load for simulating various loading conditions. Measurements are given  $\sim$  1-2minutes to stabilize.

| Eu  | Ca  | Eu             | Ca             | Po           |
|-----|-----|----------------|----------------|--------------|
| 20A | 10A | 26.15mV, 3.351 | 23.00mV, 3.353 | 0.0mV, 3.393 |
| 25A | 10A | 30.19mV, 3.361 | 25.77mV, 3.379 | 0.0mV, 3.405 |
| 30A | 10A | 35.91mV, 3.367 | 28.92mV, 3.373 | 0.0mV, 3.414 |
| 35A | 10A | 40.85mV, 3.364 | 32.27mV, 3.395 | 0.0mV, 3.420 |
| 20A | 15A | 29.15mV, 3.360 | 27.66mV, 3.365 | 0.0mV, 3.999 |
| 25A | 15A | 34.04mV, 3.367 | 31.03mV, 3.377 | 0.0mV, 3.411 |
| 30A | 15A | 38.96mV, 3.365 | 34.10mV, 3.383 | 0.0mV, 3.415 |
| 35A | 15A | 44.02mV, 3.360 | 37.61mV, 3.390 | 0.0mV, 3.433 |
| 20A | 20A | 32.33mV, 3.369 | 32.89mV, 3.361 | 0.0mV, 3.407 |
| 25A | 20A | 37.25mV, 3.367 | 36.15mV, 3.367 | 0.0mV, 3.412 |
| 30A | 20A | 42.24mV, 3.364 | 39.75mV, 3.388 | 0.0mV, 3.428 |
| 35A | 20A | 47.42mV, 3.362 | 42.94mV, 3.378 | 0.0mV, 3.435 |
| 20A | 25A | 35.65mV, 3.369 | 38.16mV, 3.353 | 0.0mV, 3.407 |

25A 25A 40.61mV, 3.364 41.45mV, 3.363 0.0mV, 3.422 30A 25A 45.72mV, 3.363 44.90mV, 3.373 0.0mV, 3.424 35A 25A 50.93mV, 3.366 48.48mV, 3.383 0.0mV, 3.434

tbr (Tim B. Robinson)

Sent:

Monday, January 30, 1995 9:41 PM

To:

'mws (Mark Semmelmeyer)'

Cc:

'dickson (Richard Dickson)'; 'geert (Geert Rosseel)'; 'woody (Jay Tomlinson)'

Subject:

Re: Euterpe timing errors

Mark Semmelmeyer wrote (on Mon Jan 30):

Of course, if the path is only 30ps over with uu-au transmission, maybe the 3 gate path will work with a local flop in AU. Then would we tolerate a 3 gate path? Should we make this change?

If you think it will fix it, I suggest making the change. At the end of the day, if it makes timing, I don't see it matters if it's a 3 gate path.

tbr

Sent:

Monday, January 30, 1995 11:29 PM

To:

'vo'; 'wamler'

Subject:

Mnemo clockbias

Follow Up Flag: Follow up

Flag Status:

Red

It looks to me like the Mnemo clockbias structure has the euterpe IO PLL to clock mast end distribution stuff in it. I assume this has come over by starting from the euterpe. What's needed to eliminate it?

tbr

Sent:

Monday, January 30, 1995 11:39 PM

To:

'wampler (Kurt Wampler)'

Subject:

Re: forwarded message from Mail Delivery Subsystem

Follow Up Flag: Follow up

Flag Status:

Red

# Kurt Wampler wrote (on Mon Jan 30):

## tbr writes:

>It looks to me like the Mnemo clockbias structure has the

>euterpe IO PLL to clock mast end distribution stuff in it.

>I assume this has come over by starting from the euterpe.

>What's needed to eliminate it?

In /u/chip/mnemo/clockbias/Makefile, we find the following code:

# Special spar designations: [nsu]%d

# BSPAR: the half-spar which will carry the main buffer chain

# CSPAR: the half-spar which will carry the clock domain control block

# RSPAR: the half-spar which will carry the auxiliary repeater chain

BSPAR = s0

RSPAR = s1

CSPAR = s2

To eliminate the repeater chain, change the "RSPAR" line to:

RSPAR = u0

The code "u" indicates that there is no repeater chain.

Then, delete "clockbias.edif" and re-run the clockbias make.

- Kurt

Great! Thanks

wampler (Kurt Wampler)

Sent:

Monday, January 30, 1995 11:39 PM

To:

'tbr'

Subject: Re: forwarded message from Mail Delivery Subsystem

### tbr writes:

>It looks to me like the Mnemo clockbias structure has the

>euterpe IO PLL to clock mast end distribution stuff in it.

>I assume this has come over by starting from the euterpe.

>What's needed to eliminate it?

In /u/chip/mnemo/clockbias/Makefile, we find the following code:

# Special spar designations: [nsu]%d

# BSPAR: the half-spar which will carry the main buffer chain

# CSPAR: the half-spar which will carry the clock domain control block

#RSPAR: the half-spar which will carry the auxiliary repeater chain

#

BSPAR = s0

RSPAR = s1

CSPAR = s2

To eliminate the repeater chain, change the "RSPAR" line to:

RSPAR = u0

The code "u" indicates that there is no repeater chain.

Then, delete "clockbias.edif" and re-run the clockbias make.

- Kurt

vanthof (vant)

Sent:

To:

Tuesday, January 31, 1995 8:05 AM 'bpw (B. P. Wong)'; 'mikew (Mike Wageman)'; 'orlando (Orlando Hernando)'; 'geert (Geert

Cc:

'vanthof (Dave Van't Hof)'; 'solo (John Campbell)'

Subject:

cache lower drc's

The lower drc's for the cache finished and the results are in:

/u/vanthof/compass/mobi/euterpe/cache.err

If anyone is interested in looking at these, have fun. The output file size is 1/10 of the previous run...

Thanks,

Dave

Dave Van't Hof vanthof@microunity.com MicroUnity Systems Engineering,

Inc.

255 Caspian Way, Sunnyvale, CA (408) 734-8100 X276 #include <std\_disclaim.h> Don't blame me, I didn't vote for him!

```
BOM 216 running on IKOS
BOM 214 ish + uu running on the zycads
uncrupt_0
                  Running now
icacheannoying 0
                      216 - Dump in /u/tbr/euterpe/verilog/bsrc
dcache func 1
                     216 hung
                                                    Trace in /n/rhodan/s3/euterpe/verilog/bsrc/res/30195.18441
dcache sz 4k 1
                     216 went to X
dcache sz 8k 1
                     216 went to X
dcache_sz_16k_1
                      216 went to bad very early in the test }
                  216 - went to bad
saaseasy
                  216 - went to bad
scaseasy
exlocktest_0
oc-interrupt U
                    206 Test fix in
brmisstest 0
bdownharder_0
                     Running in verilog now.
bgate U
ltlb 1
ex11test
                 214 Ran in verilog on 216 but test seemed to be working see wrap.log in /u/tbr/euterpe/verilog/bsrc
dram_load_config1_0
                                } 215 went to X Lisar to look at
dram_store_unique_config1_0
dramharder_config1_0
cerbarbeasy_0
                    I need to talk to Rich and Jeffm about this one
                      214
eventdaemontest 0
Have not yet been run:
saastest 0
scastest 0
uncruptharder_0
                     running now
brpcrupt 0
                  running now
brpcrupt\overline{2} 0
                   running now
brpcrupt3_0
                   running now
watchtest_0
dcache_stress_1
dcache_except_1
nb_1
```

lisar (Lisa Robinson)

Tuesday, January 31, 1995 9:28 AM 'billz'; 'dickson'; 'jeffm'; 'mws'; 'tbr'; 'woody'

From: Sent:

To:

Subject: Test status

```
nb slow 1
nb_hermes_1
nb_combo_1
oc-synch_U
oc_align_at
align_ld_1
align_st_1
doubleextest 0
cerberrtest 0
cerbstarttest 0
doublemctest 0
iorupttest_0
ruptpintest_0
brimmlongtest_0
interrupt_1
mem_1
cache_1
exception_1
bgate_1
barrel_l
synch_l
gtlb_miss_1
dcache_perf_ld1t_1
dcache_perf_stlt_l
dcache_perf_ldst1t_1
dcache_perf_ldst5t_1
addr_map_dram
fva_conflict_l
hermes_conflict_l
dcache_conflict_l
atomic_conflict_1
reg_conflict_1
interrupt U
exception_U
bgate_U
mem_U
tlb_U
synch_U
barrel_U
cache_U
gtlb_miss_U
Cannot yet be run:
instr_U
instr_1
tlb_1
insn_1
Newly available tests
xlu_rotate_1_1
xlu_rotate_2_1
```

xlu\_expand\_l\_l

```
xlu_compress_1_1
xlu_extract_1_1
xlu_field_1_1
xlu_field_2_1
xlu_field_3_1
xlu_field_4_1
xlu_field_5_1
xlu_copyswap_1_1
xlu_copyswap_2_1
xlu_copyswap_3_1
xlu_copyswap_4_1
xlu_shufflemux_1_1
xlu_select_1_1
```

# Not yet implemented:

syncharder notimp brcolltest\_0; notimp notimp brcrosstest\_0; exfixtest\_0; notimp expriotest\_0; notimp uuseqtest; notimp canceltest; notimp hermtotest; notimp notimp cerbtotest; notimp hermerrtest; notimp cerberrtest; eventregtest; notimp notimp exintbashtest; notimp address\_map; instcache; notimp cerb\_registers\_0; notimp cerberror\_0; notimp testerinit\_0; notimp

From: woody (Jay Tomlinson)

Sent: Tuesday, January 31, 1995 11:31 AM

To: 'lisar (Lisa Robinson)'

'billz'; 'dickson'; 'jeffm'; 'mws'; 'tbr' Cc:

Subject: Test status

Lisa Robinson wrote (on Tue Jan 31):

icacheannoying\_0
I will look at this one. 216 - Dump in /u/tbr/euterpe/verilog/bsrc

Jay

tbr

Sent:

Tuesday, January 31, 1995 11:40 AM

To:

'dickson'; 'mws'; 'billz'; 'lisar'; 'woody.jeffm'

Subject:

Euterpe status

Follow Up Flag: Follow up

Flag Status:

Red

10am let's take stock of current verification status.

tbr

Sent:

Tuesday, January 31, 1995 11:42 AM

To:

'hopper'; 'geert'; 'lisar'

Subject:

Euterpe tapeout date

Follow Up Flag: Follow up

Flag Status:

Red

Can we meet at 11 please to formalize the timeline for Euterpe tapeout. Mouss want's to see this at theschedule meeting tomorrow.

Sent:

tbr (Tim B. Robinson) Tuesday, January 31, 1995 11:42 AM 'hopper'; 'geert'; 'lisar'

To:

Subject:

Euterpe tapeout date

Can we meet at 11 please to formalize the timeline for Euterpe tapeout. Mouss want's to see this at the chedule meeting tomorrow.

From: billz (Bill Zuravleff)

Sent: Tuesday, January 31, 1995 11:55 AM

To: 'lisar (Lisa Robinson)'; 'tbr (Tim B. Robinson)'; 'jeffm (Jeff Marr)'; 'Mark Semmelmeyer'; 'Richard

Dickson'; 'Jay Tomlinson'

Subject: dcachenoalloc

Y'all,

test dcachenoalloc goes to X's (examined in ~tbr/euterpe/verilog/bsrc). Because LTcdMissVldCcR12 goes high while LTcdMissR12 is X. Because TDtagR7R8 is X (throughout the test).

At this point I'll have to parse the test a bit better, but ...

Surely a load or store noalloc working depends on the tag being properly initialized (it's got to know whether it was a hit or not). Does deachenoalloc initialize the tags?

The entire tag has unknown values at the beginning and end of the test.

Regards, billz

```
From:
            vo (Tom Vo)
  Sent:
            Tuesday, January 31, 1995 12:05 PM
  To:
            'Tim B. Robinson'
  Cc:
            'woody (Jay Tomlinson)'
  Subject: Re: Mnemo top level
Tim B. Robinson wrote ....
>
>I am debugging a version with the temp sensor, pll, knob city etc.
>Why is it we have vdde in the top level (using euterpe as an example),
>but not vsse?
>Tim
Don't know. Woody put that in a while back for some board level
```

stuff. We don't have vdde/vsse for calliope.

tvo

From: stick (Bruce Bateman)

Sent: Tuesday, January 31, 1995 12:06 PM

To: 'geert'; 'paulp'; 'tom'; 'vanthof'; 'hopper'

Cc: 'tbr'; 'bpw'

Subject: holes in wide metal on the cache

I understand now that we are going to fill in the holes on wide metal busses in the euterpe cache blocks and expect to 're-perforate" them to new rules which are yet to be determined. I just wanted to advise y'all that the wide busses in the read-port decode were very close to the electro-migration limit as originally designed and thus electromigration must be considered in any new proposal for bus perforation. If we reduce the effective width of these busses to any significant degree with the new rules, we could end up have a reliability problem.

BB

```
From:
           woody (Jay Tomlinson)
           Tuesday, January 31, 1995 12:49 PM
 Sent:
           'vo (Tom Vo)'
 To:
           'Tim B. Robinson'
  Cc:
  Subject: Re: Mnemo top level
Tom Vo wrote (on Tue Jan 31):
 Tim B. Robinson wrote ....
 >I am debugging a version with the temp sensor, pll, knob city etc.
 >Why is it we have vdde in the top level (using euterpe as an example),
 >but not vsse?
 >Tim
 Don't know. Woody put that in a while back for some board level
 stuff. We don't have vdde/vsse for calliope.
```

tvo

We have vdde so that we can connect it at the top level. vsse never makes it through the tab frame. In the PCAD environment we added pin 313 to connect to gnd. Calliope doesn't have this stuff. It has to be added manually in the morpheus library. Euterpe can be converted without manual intervention.

Jay

From: lisar (Lisa Robinson)

Sent: Tuesday, January 31, 1995 1:02 PM

To: 'jeffm'; 'woody'

Cc: 'tbr'

Subject: eventdaemontest

Just confirming that all 8 hermes devices are configured with event\_register\_active on.

| hermes00<br>hermes01<br>hermes02<br>hermes03 | NEVENT_REGISTER_ACTIVE 1 NEVENT_REGISTER_ACTIVE 1 NEVENT_REGISTER_ACTIVE 1 NEVENT_REGISTER_ACTIVE 1 | HERMES PROTEUSZLIB<br>HERMES PROTEUSZLIB<br>HERMES PROTEUSZLIB |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| hermes10                                     | NEVENT_REGISTER_ACTIVE 1                                                                            | HERMES PROTEUSZLIB                                             |
| hermes11                                     | NEVENT_REGISTER_ACTIVE 1                                                                            | HERMES PROTEUSZLIB                                             |
| hermes12                                     | NEVENT_REGISTER_ACTIVE 1                                                                            | HERMES PROTEUSZLIB                                             |
| hermes13                                     | NEVENT_REGISTER_ACTIVE 1                                                                            | HERMES PROTEUSZLIB                                             |

# So the trace in

/n/aphrodite/s3/euterpe/verilog/bsrc2/res/31195.27853/results/eventdaemontest.dpo

(note that this is not an exported file system).

Lisa R.

tbr

Sent:

Tuesday, January 31, 1995 2:49 PM

To:

'vo (Tom Vo)'

Subject:

Re: cli

Follow Up Flag: Follow up

Flag Status:

Red

Tom Vo wrote (on Tue Jan 31):

Tim B. Robinson wrote ....

~

>Is it right that we are using the same vrr for both the vrr and vtt

>inputs to cli?

>

>Tim

>

Does not sound right . The vtt inputs to cli should be the same as the ones going to inbyte .

Please take a look at euterpe. That's where I copied it from.

From: lisar (Lisa Robinson)

Sent: Tuesday, January 31, 1995 3:17 PM

To: 'billz'; 'jeffm'

Cc: 'tbr'

Subject: dcachenoalloc dump

Is in ~tbr/euterpe/verilog/bsrc.

Lisa R.

Exhibit C10

From: vanthof (vant)

Sent: Tuesday, January 31, 1995 3:52 PM

To: 'hardheads'

Cc: 'vanthof (Dave Van't Hof)'

Subject: fullchip drc/lvs runs starting

Hi,

I'm about to start up some fullchip drc/lvs runs on euterpe. Present plans require 6 'cpus' (3 dual processor sparc 10's) and one more machine for normal drc/lvs runs. These machines are cyclops, tomato, mothra, and medusa. Please refrain from using these machines while the fullchip runs are going. The verification runs last a minimum of 3-4 days each and many of these will be run over the next month until tapeout.

Thanks, Dave

Dave Van't Hof vanthof@microunity.com MicroUnity Systems Engineering, Inc. 255 Caspian Way, Sunnyvale, CA (408) 734-8100 X276 #include <std\_disclaim.h> Don't blame me, I didn't vote for him!

vicki [vicki@charybdis]

Sent:

Tuesday, January 31, 1995 7:35 PM

To:

'Geert Rosseel'

Subject:

Call Lieve at home.

### Ηi,

I'm about to start up some fullchip drc/lvs runs on euterpe. Present plans require 6 'cpus' (3 dual processor sparc 10's) and one more machine for normal drc/lvs runs. These machines are cyclops, tomato, mothra, and medusa.

Please refrain from using these machines while the fullchip runs are going. The verification runs last a minimum of 3-4 days each and many of these will be run over the next month until tapeout.

Thanks,

Dave

Dave Van't Hof vanthof@microunity.com MicroUnity Systems Engineering, Inc.

255 Caspian Way, Sunnyvale, CA (408) 734-8100 X276 #include <std\_disclaim.h> Don't blame me, I didn't vote for him!

```
From:
            vo (Tom Vo)
            Tuesday, January 31, 1995 11:49 PM
  Sent:
            'Tim B. Robinson'
  To:
  Subject: Re: cli
Tim B. Robinson wrote ....
>
>Tom Vo wrote (on Tue Jan 31):
>
  Tim B. Robinson wrote ....
>
>
  >Is it right that we are using the same vrr for both the vrr and vtt
>
  >inputs to cli?
>
  >Tim
>
>
  Does not sound right. The vtt inputs to cli should be the same as the ones
>
   going to iobyte.
>Please take a look at euterpe. That's where I copied it from.
>
>Tim
>
>
```

The one in euterpe.V needs fixing too. A similar problem exists in calliope with the cell clio where it propagated to euterpe.V then mnemo.V.

This hook up error prevents us from trying all values of termination resistances unless the knob dedicated to clio is set to 111. The values permitted is the bitwise AND of clio knob setting and termination value setting from cerberus.

I've issued a gnat report on this problem for calliope and checked in a change for euterpe.

tvo